aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKyrylo Tkachov <kyrylo.tkachov@arm.com>2015-12-16 10:01:48 +0000
committerKyrylo Tkachov <ktkachov@gcc.gnu.org>2015-12-16 10:01:48 +0000
commit1408479363d5f34b306c75f60a6dfbdeb5be0544 (patch)
treedba267cf5d95099eab31b0951cf42f4c2cf58f14
parent8155f4d8cfd834e7cf1151a41fe0773477504f48 (diff)
downloadgcc-1408479363d5f34b306c75f60a6dfbdeb5be0544.zip
gcc-1408479363d5f34b306c75f60a6dfbdeb5be0544.tar.gz
gcc-1408479363d5f34b306c75f60a6dfbdeb5be0544.tar.bz2
[ARM] PR target/68648: Fold NOT of CONST_INT in andsi_iorsi3_notsi splitter
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
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/config/arm/arm.md18
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.c-torture/execute/pr68648.c20
4 files changed, 47 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 6450d52..464558f 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -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
diff --git a/gcc/config/arm/arm.md b/gcc/config/arm/arm.md
index a91873c..2683361 100644
--- a/gcc/config/arm/arm.md
+++ b/gcc/config/arm/arm.md
@@ -3228,8 +3228,22 @@
"#" ; "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")
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 7a3c5e4..d90d43c 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -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
index 0000000..fc66806
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/execute/pr68648.c
@@ -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 ();
+}