re PR target/91269 (unaligned floating-point register with -mcpu=niagara4 -fcall...
authorEric Botcazou <ebotcazou@adacore.com>
Fri, 20 Sep 2019 09:42:40 +0000 (09:42 +0000)
committerEric Botcazou <ebotcazou@gcc.gnu.org>
Fri, 20 Sep 2019 09:42:40 +0000 (09:42 +0000)
PR target/91269
* config/sparc/sparc.h (HARD_REGNO_CALLER_SAVE_MODE): Define.

From-SVN: r275994

gcc/ChangeLog
gcc/config/sparc/sparc.h
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/pr91269.c [new file with mode: 0644]

index bda334b2df8667b142598e69b14d71b8e6e7a13f..c841fffa7f71aee9f0273a095101c07c9894c3c1 100644 (file)
@@ -1,3 +1,8 @@
+2019-09-20  Eric Botcazou  <ebotcazou@adacore.com>
+
+       PR target/91269
+       * config/sparc/sparc.h (HARD_REGNO_CALLER_SAVE_MODE): Define.
+
 2019-09-20  Richard Biener  <rguenther@suse.de>
 
        PR tree-optimization/91822
index defcba8ecd775eed8a0e06d08a5eab8e898fb5dc..d14741846f573bb7ed336d632df24c27a7624fef 100644 (file)
@@ -711,6 +711,13 @@ along with GCC; see the file COPYING3.  If not see
    register window instruction in the prologue.  */
 #define HARD_REGNO_RENAME_OK(FROM, TO) ((FROM) != 1)
 
+/* Select a register mode required for caller save of hard regno REGNO.
+   Contrary to what is documented, the default is not the smallest suitable
+   mode but the largest suitable mode for the given (REGNO, NREGS) pair and
+   it quickly creates paradoxical subregs that can be problematic.  */
+#define HARD_REGNO_CALLER_SAVE_MODE(REGNO, NREGS, MODE) \
+  ((MODE) == VOIDmode ? choose_hard_reg_mode (REGNO, NREGS, false) : (MODE))
+
 /* Specify the registers used for certain standard purposes.
    The values of these macros are register numbers.  */
 
index 59c6b7991ad6b2ee95f6cd55b34b874f79584bea..8e1b4be2c012d89189963f6184731e6a6bcb0703 100644 (file)
@@ -1,3 +1,7 @@
+2019-09-20  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * gcc.dg/pr91269.c: New test.
+
 2019-09-20  Eric Botcazou  <ebotcazou@adacore.com>
 
        * gcc.dg/typedef-var-1.c: New test.
diff --git a/gcc/testsuite/gcc.dg/pr91269.c b/gcc/testsuite/gcc.dg/pr91269.c
new file mode 100644 (file)
index 0000000..8c03ba8
--- /dev/null
@@ -0,0 +1,70 @@
+/* PR target/91269 */
+/* Testcase by Sergei Trofimovich <slyfox@inbox.ru> */
+
+/* { dg-do assemble } */
+/* { dg-options "-O2 -Wno-int-conversion" }  */
+/* { dg-additional-options "-fcall-used-g6 -fPIE -mcpu=niagara4" { target sparc*-*-* } } */
+
+struct m;
+
+enum { a = 2 };
+int b[1];
+int d[2715];
+int e, f, h;
+enum { i = 2 } j;
+inline int c(int k) {
+  char *cp;
+  if (k >= 62 && k <= 247)
+    cp = b[k];
+  if (cp)
+    return 65533;
+  return 2;
+}
+inline int g(int k) {
+  if (k < sizeof(d))
+    return e;
+  return 0;
+}
+
+int u(struct m*, char*, char*);
+
+int l(struct m *k, char n, long o, int *p) {
+  int q, flags = j, r, s, lasttwo = *p;
+  char inptr, outptr;
+  while (inptr) {
+    if (__builtin_expect(h, 0))
+      break;
+    unsigned ch = inptr;
+    if (lasttwo) {
+      long need = lasttwo >> 3;
+      if (__builtin_expect(need > n, 0))
+        break;
+    } else if (s == i) {
+      long t = c(ch);
+      if (t != 65533) {
+        int jch = g(ch);
+        if (jch & 8)
+          continue;
+      }
+    }
+    if (ch <= 5)
+      ;
+    else {
+      long t = c(ch);
+      if (t != 65533)
+        ;
+      else {
+        switch (f >> 8)
+        case 79:
+          q = f == 20308 || f == 20350;
+        if (q)
+          if (j)
+            r = u(k, &inptr, &outptr);
+        s = *p;
+        if (r)
+          if (o && flags & a)
+            break;
+      }
+    }
+  }
+}