aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Biener <rguenther@suse.de>2016-11-29 07:48:43 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2016-11-29 07:48:43 +0000
commitb302f2e058a37b462e8c78216a65ff7341a58bf1 (patch)
tree9b77ab75e716b944c064b82a8664b83ab6b8d993
parente24dcd7d2a9bed04d1662b4930d26e8d4e47b354 (diff)
downloadgcc-b302f2e058a37b462e8c78216a65ff7341a58bf1.zip
gcc-b302f2e058a37b462e8c78216a65ff7341a58bf1.tar.gz
gcc-b302f2e058a37b462e8c78216a65ff7341a58bf1.tar.bz2
re PR rtl-optimization/78546 (wrong code at -O2 and above)
2016-11-29 Richard Biener <rguenther@suse.de> PR middle-end/78546 * match.pd: Add CST1 - (CST2 - A) -> CST3 + A missing case. * gcc.dg/tree-ssa/forwprop-36.c: New testcase. From-SVN: r242953
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/match.pd11
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/tree-ssa/forwprop-36.c24
4 files changed, 43 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index fb25f75..c1dd877 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2016-11-29 Richard Biener <rguenther@suse.de>
+
+ PR middle-end/78546
+ * match.pd: Add CST1 - (CST2 - A) -> CST3 + A missing case.
+
2016-11-29 Janus Weil <janus@gcc.gnu.org>
* doc/contrib.texi: Add a few missing gfortran contributors.
diff --git a/gcc/match.pd b/gcc/match.pd
index 2d4e019..bc8a5e7 100644
--- a/gcc/match.pd
+++ b/gcc/match.pd
@@ -1195,7 +1195,7 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
(minus @0 (minus @0 @1))
@1)
- /* (A +- CST) +- CST -> A + CST */
+ /* (A +- CST1) +- CST2 -> A + CST3 */
(for outer_op (plus minus)
(for inner_op (plus minus)
(simplify
@@ -1208,7 +1208,7 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
(if (cst && !TREE_OVERFLOW (cst))
(inner_op @0 { cst; } ))))))
- /* (CST - A) +- CST -> CST - A */
+ /* (CST1 - A) +- CST2 -> CST3 - A */
(for outer_op (plus minus)
(simplify
(outer_op (minus CONSTANT_CLASS_P@1 @0) CONSTANT_CLASS_P@2)
@@ -1216,6 +1216,13 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
(if (cst && !TREE_OVERFLOW (cst))
(minus { cst; } @0)))))
+ /* CST1 - (CST2 - A) -> CST3 + A */
+ (simplify
+ (minus CONSTANT_CLASS_P@1 (minus CONSTANT_CLASS_P@2 @0))
+ (with { tree cst = const_binop (MINUS_EXPR, type, @1, @2); }
+ (if (cst && !TREE_OVERFLOW (cst))
+ (plus { cst; } @0))))
+
/* ~A + A -> -1 */
(simplify
(plus:c (bit_not @0) @0)
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index b325e2c..d209fcb 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2016-11-29 Richard Biener <rguenther@suse.de>
+
+ PR middle-end/78546
+ * gcc.dg/tree-ssa/forwprop-36.c: New testcase.
+
2016-11-29 Segher Boessenkool <segher@kernel.crashing.org>
* gcc.target/powerpc/rldic-0.c: New testcase.
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/forwprop-36.c b/gcc/testsuite/gcc.dg/tree-ssa/forwprop-36.c
new file mode 100644
index 0000000..9de73ff
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/tree-ssa/forwprop-36.c
@@ -0,0 +1,24 @@
+/* { dg-do compile { target int128 } } */
+/* { dg-options "-O -fdump-tree-cddce1" } */
+
+typedef unsigned __int128 u128;
+
+u128 a, b;
+
+static inline u128
+foo (u128 p1)
+{
+ p1 += ~b;
+ return -p1;
+}
+
+int
+main ()
+{
+ u128 x = foo (~0x7fffffffffffffff);
+ if (x != 0x8000000000000001)
+ __builtin_abort();
+ return 0;
+}
+
+/* { dg-final { scan-tree-dump "if \\(b.0_\[0-9\]+ != 0\\)" "cddce1" } } */