aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2002-08-05 21:26:27 +0200
committerJakub Jelinek <jakub@gcc.gnu.org>2002-08-05 21:26:27 +0200
commit1bed5ee327933809acc2bb4a95fdcf8254d7ffa5 (patch)
treea306730481abb5c80e103e5c05910fd1b4693506 /gcc
parent5133ad466a642ee5080d8632fc8fca21478362bf (diff)
downloadgcc-1bed5ee327933809acc2bb4a95fdcf8254d7ffa5.zip
gcc-1bed5ee327933809acc2bb4a95fdcf8254d7ffa5.tar.gz
gcc-1bed5ee327933809acc2bb4a95fdcf8254d7ffa5.tar.bz2
fold-const.c (associate_trees): Only optimize NEGATE_EXPR in one of the operands into MINUS_EXPR if...
* fold-const.c (associate_trees): Only optimize NEGATE_EXPR in one of the operands into MINUS_EXPR if code is PLUS_EXPR. * gcc.c-torture/execute/20020805-1.c: New test. From-SVN: r56058
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/fold-const.c18
-rw-r--r--gcc/testsuite/ChangeLog2
-rw-r--r--gcc/testsuite/gcc.c-torture/execute/20020805-1.c21
4 files changed, 38 insertions, 8 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index c59b320..baa6118 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2002-08-05 Jakub Jelinek <jakub@redhat.com>
+
+ * fold-const.c (associate_trees): Only optimize NEGATE_EXPR in one
+ of the operands into MINUS_EXPR if code is PLUS_EXPR.
+
2002-08-05 Douglas B Rupp <rupp@gnat.com>
* config.gcc (i[34567]86-*-interix*): Replace interix.o with winnt.o
diff --git a/gcc/fold-const.c b/gcc/fold-const.c
index 7751e65..033dbfcf 100644
--- a/gcc/fold-const.c
+++ b/gcc/fold-const.c
@@ -1001,14 +1001,16 @@ associate_trees (t1, t2, code, type)
if (TREE_CODE (t1) == code || TREE_CODE (t2) == code
|| TREE_CODE (t1) == MINUS_EXPR || TREE_CODE (t2) == MINUS_EXPR)
{
- if (TREE_CODE (t1) == NEGATE_EXPR)
- return build (MINUS_EXPR, type, convert (type, t2),
- convert (type, TREE_OPERAND (t1, 0)));
- else if (TREE_CODE (t2) == NEGATE_EXPR)
- return build (MINUS_EXPR, type, convert (type, t1),
- convert (type, TREE_OPERAND (t2, 0)));
- else
- return build (code, type, convert (type, t1), convert (type, t2));
+ if (code == PLUS_EXPR)
+ {
+ if (TREE_CODE (t1) == NEGATE_EXPR)
+ return build (MINUS_EXPR, type, convert (type, t2),
+ convert (type, TREE_OPERAND (t1, 0)));
+ else if (TREE_CODE (t2) == NEGATE_EXPR)
+ return build (MINUS_EXPR, type, convert (type, t1),
+ convert (type, TREE_OPERAND (t2, 0)));
+ }
+ return build (code, type, convert (type, t1), convert (type, t2));
}
return fold (build (code, type, convert (type, t1), convert (type, t2)));
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index ea7dbc6..6f0baea 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -2,6 +2,8 @@
* consistency.vlad/layout/endian.c: Include string.h.
+ * gcc.c-torture/execute/20020805-1.c: New test.
+
2002-08-04 Gabriel Dos Reis <gdr@nerim.net>
* g++.dg/other/conversion1.C: New test.
diff --git a/gcc/testsuite/gcc.c-torture/execute/20020805-1.c b/gcc/testsuite/gcc.c-torture/execute/20020805-1.c
new file mode 100644
index 0000000..e7d5179
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/execute/20020805-1.c
@@ -0,0 +1,21 @@
+/* This testcase was miscompiled on IA-32, because fold-const
+ assumed associate_trees is always done on PLUS_EXPR. */
+
+extern void abort (void);
+extern void exit (int);
+
+void check (unsigned int m)
+{
+ if (m != (unsigned int) -1)
+ abort ();
+}
+
+unsigned int n = 1;
+
+int main (void)
+{
+ unsigned int m;
+ m = (1 | (2 - n)) | (-n);
+ check (m);
+ exit (0);
+}