[ARM] PR target/68648: Fold NOT of CONST_INT in andsi_iorsi3_notsi splitter
authorKyrylo Tkachov <kyrylo.tkachov@arm.com>
Wed, 16 Dec 2015 10:01:48 +0000 (10:01 +0000)
committerKyrylo Tkachov <ktkachov@gcc.gnu.org>
Wed, 16 Dec 2015 10:01:48 +0000 (10:01 +0000)
PR target/68648
* config/arm/arm.md (*andsi_iorsi3_notsi): Try to simplify
the complement of operands[3] during splitting.

* gcc.c-torture/execute/pr68648.c: New test.

From-SVN: r231675

gcc/ChangeLog
gcc/config/arm/arm.md
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.c-torture/execute/pr68648.c [new file with mode: 0644]

index 6450d52..464558f 100644 (file)
@@ -1,3 +1,9 @@
+2015-12-16  Kyrylo Tkachov  <kyrylo.tkachov@arm.com>
+
+       PR target/68648
+       * config/arm/arm.md (*andsi_iorsi3_notsi): Try to simplify
+       the complement of operands[3] during splitting.
+
 2015-12-16  Richard Biener  <rguenther@suse.de>
 
        PR tree-optimization/68892
index a91873c..2683361 100644 (file)
   "#"   ; "orr%?\\t%0, %1, %2\;bic%?\\t%0, %0, %3"
   "&& reload_completed"
   [(set (match_dup 0) (ior:SI (match_dup 1) (match_dup 2)))
-   (set (match_dup 0) (and:SI (not:SI (match_dup 3)) (match_dup 0)))]
-  ""
+   (set (match_dup 0) (and:SI (match_dup 4) (match_dup 5)))]
+  {
+     /* If operands[3] is a constant make sure to fold the NOT into it
+       to avoid creating a NOT of a CONST_INT.  */
+    rtx not_rtx = simplify_gen_unary (NOT, SImode, operands[3], SImode);
+    if (CONST_INT_P (not_rtx))
+      {
+       operands[4] = operands[0];
+       operands[5] = not_rtx;
+      }
+    else
+      {
+       operands[5] = operands[0];
+       operands[4] = not_rtx;
+      }
+  }
   [(set_attr "length" "8")
    (set_attr "ce_count" "2")
    (set_attr "predicable" "yes")
index 7a3c5e4..d90d43c 100644 (file)
@@ -1,3 +1,8 @@
+2015-12-16  Kyrylo Tkachov  <kyrylo.tkachov@arm.com>
+
+       PR target/68648
+       * gcc.c-torture/execute/pr68648.c: New test.
+
 2015-12-16  Richard Biener  <rguenther@suse.de>
 
        PR tree-optimization/68892
diff --git a/gcc/testsuite/gcc.c-torture/execute/pr68648.c b/gcc/testsuite/gcc.c-torture/execute/pr68648.c
new file mode 100644 (file)
index 0000000..fc66806
--- /dev/null
@@ -0,0 +1,20 @@
+int __attribute__ ((noinline))
+foo (void)
+{
+  return 123;
+}
+
+int __attribute__ ((noinline))
+bar (void)
+{
+  int c = 1;
+  c |= 4294967295 ^ (foo () | 4073709551608);
+  return c;
+}
+
+int
+main ()
+{
+  if (bar () != 0x83fd4005)
+    __builtin_abort ();
+}