aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2009-04-22 23:57:52 +0200
committerJakub Jelinek <jakub@gcc.gnu.org>2009-04-22 23:57:52 +0200
commit2c0eba5af00a2544e7e15bd8052a53bdb2b6f22f (patch)
tree9490a0f1996cc98864effb946df615d1062f9693
parent023f059b5c168cb31e8818d2c983f5687b169df4 (diff)
downloadgcc-2c0eba5af00a2544e7e15bd8052a53bdb2b6f22f.zip
gcc-2c0eba5af00a2544e7e15bd8052a53bdb2b6f22f.tar.gz
gcc-2c0eba5af00a2544e7e15bd8052a53bdb2b6f22f.tar.bz2
re PR c/39855 (Shift optimization discards operands' side effects)
PR c/39855 * fold-const.c (fold_binary) <case LSHIFT_EXPR>: When optimizing into 0, use omit_one_operand. * gcc.dg/torture/pr39855.c: New test. From-SVN: r146617
-rw-r--r--gcc/ChangeLog4
-rw-r--r--gcc/fold-const.c3
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/torture/pr39855.c24
4 files changed, 35 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 9073054..7bc4f33 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -3,6 +3,10 @@
* alias.c (find_base_term): Move around LO_SUM case, so that
CONST falls through into PLUS/MINUS handling.
+ PR c/39855
+ * fold-const.c (fold_binary) <case LSHIFT_EXPR>: When optimizing
+ into 0, use omit_one_operand.
+
2009-04-23 Ben Elliston <bje@au.ibm.com>
* config/rs6000/linux-unwind.h (get_regs): Remove type
diff --git a/gcc/fold-const.c b/gcc/fold-const.c
index ca07cf1..f0ff5b6 100644
--- a/gcc/fold-const.c
+++ b/gcc/fold-const.c
@@ -11880,7 +11880,8 @@ fold_binary (enum tree_code code, tree type, tree op0, tree op1)
if (code == LROTATE_EXPR || code == RROTATE_EXPR)
low = low % TYPE_PRECISION (type);
else if (TYPE_UNSIGNED (type) || code == LSHIFT_EXPR)
- return build_int_cst (type, 0);
+ return omit_one_operand (type, build_int_cst (type, 0),
+ TREE_OPERAND (arg0, 0));
else
low = TYPE_PRECISION (type) - 1;
}
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index e5c7010..7af7fcc 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2009-04-22 Jakub Jelinek <jakub@redhat.com>
+
+ PR c/39855
+ * gcc.dg/torture/pr39855.c: New test.
+
2009-04-22 Dodji Seketeli <dodji@redhat.com>
PR c++/39639
diff --git a/gcc/testsuite/gcc.dg/torture/pr39855.c b/gcc/testsuite/gcc.dg/torture/pr39855.c
new file mode 100644
index 0000000..6d75c38
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/torture/pr39855.c
@@ -0,0 +1,24 @@
+/* PR c/39855 */
+/* { dg-do run { target { int32plus } } } */
+
+extern void abort (void);
+
+int i, j, k;
+
+int
+foo (void)
+{
+ return ++i;
+}
+
+int
+main ()
+{
+ if (__CHAR_BIT__ != 8 || sizeof (int) != 4)
+ return 0;
+ j = foo () << 30 << 2;
+ k = (unsigned) foo () >> 16 >> 16;
+ if (i != 2 || j != 0 || k != 0)
+ abort ();
+ return 0;
+}