aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2019-03-20 12:26:42 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2019-03-20 12:26:42 +0100
commita5b821e448e6debe73e1154128b4ea6f7f73fbdd (patch)
tree6e4940308ba8d348193ea382c21c257c79a66ab8
parent7f129d6f1619d81cac4dd0ac58071442e99466ea (diff)
downloadgcc-a5b821e448e6debe73e1154128b4ea6f7f73fbdd.zip
gcc-a5b821e448e6debe73e1154128b4ea6f7f73fbdd.tar.gz
gcc-a5b821e448e6debe73e1154128b4ea6f7f73fbdd.tar.bz2
re PR target/89752 (ICE in emit_move_insn, at expr.c:3723)
PR target/89752 * lra-constraints.c (process_alt_operands) <reg>: For BLKmode, don't update this_alternative nor this_alternative_set. * g++.target/aarch64/aarch64.exp: New file. * g++.target/aarch64/pr89752.C: New test. From-SVN: r269819
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/lra-constraints.c4
-rw-r--r--gcc/testsuite/ChangeLog6
-rw-r--r--gcc/testsuite/g++.target/aarch64/aarch64.exp44
-rw-r--r--gcc/testsuite/g++.target/aarch64/pr89752.C11
5 files changed, 69 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index adf1382..9b32d93 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2019-03-20 Jakub Jelinek <jakub@redhat.com>
+
+ PR target/89752
+ * lra-constraints.c (process_alt_operands) <reg>: For BLKmode, don't
+ update this_alternative nor this_alternative_set.
+
2019-03-19 Jim Wilson <jimw@sifive.com>
PR target/89411
diff --git a/gcc/lra-constraints.c b/gcc/lra-constraints.c
index ccca130..cba87eb 100644
--- a/gcc/lra-constraints.c
+++ b/gcc/lra-constraints.c
@@ -2350,6 +2350,8 @@ process_alt_operands (int only_alternative)
break;
reg:
+ if (mode == BLKmode)
+ break;
this_alternative = reg_class_subunion[this_alternative][cl];
IOR_HARD_REG_SET (this_alternative_set,
reg_class_contents[cl]);
@@ -2360,8 +2362,6 @@ process_alt_operands (int only_alternative)
IOR_HARD_REG_SET (this_costly_alternative_set,
reg_class_contents[cl]);
}
- if (mode == BLKmode)
- break;
winreg = true;
if (REG_P (op))
{
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index e60ec93..b6a42d9 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,9 @@
+2019-03-20 Jakub Jelinek <jakub@redhat.com>
+
+ PR target/89752
+ * g++.target/aarch64/aarch64.exp: New file.
+ * g++.target/aarch64/pr89752.C: New test.
+
2019-03-19 Martin Sebor <msebor@redhat.com>
PR tree-optimization/89688
diff --git a/gcc/testsuite/g++.target/aarch64/aarch64.exp b/gcc/testsuite/g++.target/aarch64/aarch64.exp
new file mode 100644
index 0000000..22d8042
--- /dev/null
+++ b/gcc/testsuite/g++.target/aarch64/aarch64.exp
@@ -0,0 +1,44 @@
+# Specific regression driver for AArch64.
+# Copyright (C) 2009-2019 Free Software Foundation, Inc.
+#
+# This file is part of GCC.
+#
+# GCC is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3, or (at your option)
+# any later version.
+#
+# GCC is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+# General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with GCC; see the file COPYING3. If not see
+# <http://www.gnu.org/licenses/>. */
+
+# GCC testsuite that uses the `dg.exp' driver.
+
+# Exit immediately if this isn't an AArch64 target.
+if {![istarget aarch64*-*-*] } then {
+ return
+}
+
+# Load support procs.
+load_lib g++-dg.exp
+
+global DEFAULT_CXXFLAGS
+if ![info exists DEFAULT_CXXFLAGS] then {
+ set DEFAULT_CXXFLAGS " -pedantic-errors"
+}
+
+# Initialize `dg'.
+dg-init
+
+# Main loop.
+dg-runtest [lsort [glob -nocomplain $srcdir/$subdir/*.C]] \
+ "" $DEFAULT_CXXFLAGS
+
+# All done.
+dg-finish
+
diff --git a/gcc/testsuite/g++.target/aarch64/pr89752.C b/gcc/testsuite/g++.target/aarch64/pr89752.C
new file mode 100644
index 0000000..6beea74
--- /dev/null
+++ b/gcc/testsuite/g++.target/aarch64/pr89752.C
@@ -0,0 +1,11 @@
+// PR target/89752
+// { dg-do compile }
+
+struct A { A (); ~A (); short c; };
+
+void
+foo ()
+{
+ A a0, a1;
+ __asm volatile ("" : "=rm" (a0), "=rm" (a1) : "0" (a0), "1" (a1)); // { dg-error "inconsistent operand constraints in an 'asm'" }
+}