summaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>2007-02-24 19:55:47 +0000
committerrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>2007-02-24 19:55:47 +0000
commit428b02b455d432f94f3c804dddb49392b2de3011 (patch)
tree519e3bd036acaa7e2d9abb7b298d90d27eb168d5 /gcc
parent40f89ebf453edf50b8dd69e7df4d8ca71eefff35 (diff)
downloadgcc-428b02b455d432f94f3c804dddb49392b2de3011.tar.gz
2007-02-24 Richard Guenther <rguenther@suse.de>
PR middle-end/30951 * fold-const.c (fold_binary): Fold x +- CST op x for EQ_EXPR and NE_EXPR. * gcc.dg/pr30951.c: New testcase. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@122295 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/fold-const.c18
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/pr30951.c36
4 files changed, 65 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 58980dcd200..2368d6a0155 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2007-02-24 Richard Guenther <rguenther@suse.de>
+
+ PR middle-end/30951
+ * fold-const.c (fold_binary): Fold x +- CST op x for
+ EQ_EXPR and NE_EXPR.
+
2007-02-24 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
* pa.md (muldi3): Force subregs to registers in 64-bit expander.
diff --git a/gcc/fold-const.c b/gcc/fold-const.c
index ffd63cf5e7e..80c3c41ecff 100644
--- a/gcc/fold-const.c
+++ b/gcc/fold-const.c
@@ -11203,6 +11203,24 @@ fold_binary (enum tree_code code, tree type, tree op0, tree op1)
fold_convert (TREE_TYPE (arg0), arg1),
TREE_OPERAND (arg0, 1)));
+ /* Transform comparisons of the form X +- C CMP X. */
+ if ((TREE_CODE (arg0) == PLUS_EXPR || TREE_CODE (arg0) == MINUS_EXPR)
+ && operand_equal_p (TREE_OPERAND (arg0, 0), arg1, 0)
+ && TREE_CODE (TREE_OPERAND (arg0, 1)) == INTEGER_CST
+ && (INTEGRAL_TYPE_P (TREE_TYPE (arg0))
+ || POINTER_TYPE_P (TREE_TYPE (arg0))))
+ {
+ tree cst = TREE_OPERAND (arg0, 1);
+
+ if (code == EQ_EXPR
+ && !integer_zerop (cst))
+ return omit_two_operands (type, boolean_false_node,
+ TREE_OPERAND (arg0, 0), arg1);
+ else
+ return omit_two_operands (type, boolean_true_node,
+ TREE_OPERAND (arg0, 0), arg1);
+ }
+
/* If we have X - Y == 0, we can convert that to X == Y and similarly
for !=. Don't do this for ordered comparisons due to overflow. */
if (TREE_CODE (arg0) == MINUS_EXPR
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index a4b1af91207..bd67ab6de6b 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2007-02-24 Richard Guenther <rguenther@suse.de>
+
+ PR middle-end/30951
+ * gcc.dg/pr30951.c: New testcase.
+
2007-02-24 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
* gcc.dg/torture/builtin-modf-1.c: New test.
diff --git a/gcc/testsuite/gcc.dg/pr30951.c b/gcc/testsuite/gcc.dg/pr30951.c
new file mode 100644
index 00000000000..149b8ecaafd
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/pr30951.c
@@ -0,0 +1,36 @@
+/* { dg-do link } */
+
+extern void link_error (void);
+
+void test (int x, unsigned int y)
+{
+ if (x + 5 == x)
+ link_error ();
+ if (x == x + 10)
+ link_error ();
+ if (y + 5 == y)
+ link_error ();
+ if (y == y + 10)
+ link_error ();
+ if (x + 5 != x)
+ ;
+ else
+ link_error ();
+ if (x != x + 10)
+ ;
+ else
+ link_error ();
+ if (y + 5 != y)
+ ;
+ else
+ link_error ();
+ if (y != y + 10)
+ ;
+ else
+ link_error ();
+}
+
+int main()
+{
+ return 0;
+}