]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
rs6000: Fix infinite loop building ghostscript and icu [PR93658]
authorPeter Bergner <bergner@linux.ibm.com>
Mon, 24 Feb 2020 00:22:57 +0000 (18:22 -0600)
committerPeter Bergner <bergner@linux.ibm.com>
Mon, 24 Feb 2020 00:31:56 +0000 (18:31 -0600)
Fix rs6000_legitimate_address_p(), which erroneously marks a valid Altivec
address as being invalid, which causes LRA's process_address()  to go into
an infinite loop spilling the same address over and over again.
Include Mike's earlier commits that fix bugs this patch exposes.

Backport from master
2020-02-20  Peter Bergner  <bergner@linux.ibm.com>

PR target/93658
* config/rs6000/rs6000.c (rs6000_legitimate_address_p): Handle VSX
vector modes.

* gcc.target/powerpc/pr93658.c: New test.

gcc/ChangeLog
gcc/config/rs6000/rs6000.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/powerpc/pr93658.c [new file with mode: 0644]

index ec6600af08865b0a95e4c831226eda5bb49b88ee..8d8dbc0bdff544501c3185bb371a175576b9dc2f 100644 (file)
@@ -1,3 +1,12 @@
+2020-02-23  Peter Bergner <bergner@linux.ibm.com>
+
+       Backport from master
+       2020-02-20  Peter Bergner  <bergner@linux.ibm.com>
+
+       PR target/93658
+       * config/rs6000/rs6000.c (rs6000_legitimate_address_p): Handle VSX
+       vector modes.
+
 2020-02-23  Peter Bergner <bergner@linux.ibm.com>
 
        Backport from master
index ce1bd3262d19a0fdec0084cd989d4451b6e74982..1d93570e7a59b23e16f3d6d9eb9262f4aab9febf 100644 (file)
@@ -9358,7 +9358,7 @@ rs6000_legitimate_address_p (machine_mode mode, rtx x, bool reg_ok_strict)
   bool quad_offset_p = mode_supports_dq_form (mode);
 
   /* If this is an unaligned stvx/ldvx type address, discard the outer AND.  */
-  if (VECTOR_MEM_ALTIVEC_P (mode)
+  if (VECTOR_MEM_ALTIVEC_OR_VSX_P (mode)
       && GET_CODE (x) == AND
       && CONST_INT_P (XEXP (x, 1))
       && INTVAL (XEXP (x, 1)) == -16)
index 9344d00e38a50d33cc9f4024edc414e664e8bc4e..f02a941523009050d7e18f1943a923d9c0ecdf29 100644 (file)
@@ -1,3 +1,11 @@
+2020-02-23  Peter Bergner  <bergner@linux.ibm.com>
+
+       Backport from master
+       2020-02-20  Peter Bergner  <bergner@linux.ibm.com>
+
+       PR target/93658
+       * gcc.target/powerpc/pr93658.c: New test.
+
 2020-02-20  H.J. Lu  <hongjiu.lu@intel.com>
 
        Backport from master
diff --git a/gcc/testsuite/gcc.target/powerpc/pr93658.c b/gcc/testsuite/gcc.target/powerpc/pr93658.c
new file mode 100644 (file)
index 0000000..0170d34
--- /dev/null
@@ -0,0 +1,20 @@
+/* { dg-do compile } */
+/* { dg-options "-O3 -fstack-protector-strong -mcpu=power8" } */
+/* { dg-require-effective-target powerpc_vsx_ok } */
+
+/* PR93658: Failure compiling this test is an infinite loop in LRA's
+   process_address(), so set a short timeout limit.  */
+/* { dg-timeout 5 } */
+
+void bar();
+char b;
+void
+foo (void)
+{
+  char a;
+  int d = b;
+  char *e = &a;
+  while (d)
+    *e++ = --d;
+  bar ();
+}