S/390: Fix PR87723
authorAndreas Krebbel <krebbel@linux.ibm.com>
Tue, 6 Nov 2018 10:22:05 +0000 (10:22 +0000)
committerAndreas Krebbel <krebbel@gcc.gnu.org>
Tue, 6 Nov 2018 10:22:05 +0000 (10:22 +0000)
gcc/ChangeLog:

2018-11-06  Andreas Krebbel  <krebbel@linux.ibm.com>

PR target/87723
* config/s390/s390.md ("*r<noxa>sbg_di_rotl"): Remove mode
attributes for operands 3 and 4.

gcc/testsuite/ChangeLog:

2018-11-06  Andreas Krebbel  <krebbel@linux.ibm.com>

PR target/87723
* gcc.target/s390/pr87723.c: New test.

From-SVN: r265832

gcc/ChangeLog
gcc/config/s390/s390.md
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/s390/pr87723.c [new file with mode: 0644]

index b4b36e0b5704e6a3e20ac0ba1c70ee9aeeb5e724..f5be58abfef8cc31b197548e21d78f7e3779dc85 100644 (file)
@@ -1,3 +1,9 @@
+2018-11-06  Andreas Krebbel  <krebbel@linux.ibm.com>
+
+       PR target/87723
+       * config/s390/s390.md ("*r<noxa>sbg_di_rotl"): Remove mode
+       attributes for operands 3 and 4.
+
 2018-11-06  Richard Biener  <rguenther@suse.de>
 
        PR middle-end/18041
index 8e7b285e1c3360a388146ba3d4284299d16804d8..4ffd438c07cee7241024ed6a42c134a47b3d4184 100644 (file)
          (match_operand:DI 4 "nonimmediate_operand" "0")))
    (clobber (reg:CC CC_REGNUM))]
   "TARGET_Z10"
-  "r<noxa>sbg\t%0,%1,%<bfstart>2,%<bfend>2,%b3"
+  "r<noxa>sbg\t%0,%1,%s2,%e2,%b3"
   [(set_attr "op_type" "RIE")])
 
 ; rosbg, rxsbg
index 0bfb80f468bfc04c2f8aac43c98a8f502b527124..17f696860fa2c0bd5ee79a29c9f317968a7880a0 100644 (file)
@@ -1,3 +1,8 @@
+2018-11-06  Andreas Krebbel  <krebbel@linux.ibm.com>
+
+       PR target/87723
+       * gcc.target/s390/pr87723.c: New test.
+
 2018-11-06  Richard Biener  <rguenther@suse.de>
 
        PR middle-end/18041
diff --git a/gcc/testsuite/gcc.target/s390/pr87723.c b/gcc/testsuite/gcc.target/s390/pr87723.c
new file mode 100644 (file)
index 0000000..b0e8a5a
--- /dev/null
@@ -0,0 +1,29 @@
+/* { dg-do compile } */
+/* { dg-options "-O3 -march=z196 -m64 -mzarch" } */
+
+unsigned long a;
+int b;
+void c(char* i) {
+  for (;;) {
+    char g = 0;
+    for (; g < 24; ++g)
+      b = a << g | a >> 64 - g;
+    {
+      char *d = i;
+      long h = b;
+      char e = 0;
+      for (; e < 8; ++e)
+       d[e] = h;
+    }
+    char *d = i;
+    signed e;
+    unsigned long f = 0;
+    e = 7;
+    for (; e; --e) {
+      f <<= 8;
+      f |= d[e];
+    }
+    for (; e < 8; ++e)
+      d[e] = f;
+  }
+}