2004-03-23 Kazu Hirata <kazu@cs.umass.edu>
authorsayle <sayle@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 23 Mar 2004 14:26:43 +0000 (14:26 +0000)
committersayle <sayle@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 23 Mar 2004 14:26:43 +0000 (14:26 +0000)
PR optimization/14669
* fold-const.c (fold): Only unwiden integer comparisons for equality
or inequality operators, or when the signedness is the same.

* g++.dg/opt/fold2.C: New test case.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@79859 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/fold-const.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/opt/fold2.C [new file with mode: 0644]

index deb8826..5343f2c 100644 (file)
@@ -1,3 +1,9 @@
+2004-03-23  Kazu Hirata  <kazu@cs.umass.edu>
+
+       PR optimization/14669
+       * fold-const.c (fold): Only unwiden integer comparisons for equality
+       and inequality operators, or when the signedness doesn't change.
+
 2004-03-23  Jakub Jelinek  <jakub@redhat.com>
 
        * config.gcc (sparc-*-linux*): Add sparc/t-linux to tmake_file.
index 84c6055..ab43be8 100644 (file)
@@ -7535,6 +7535,9 @@ fold (tree expr)
       else if (TREE_CODE (TREE_TYPE (arg0)) == INTEGER_TYPE
               && TREE_CODE (arg0) == NOP_EXPR
               && (tem = get_unwidened (arg0, NULL_TREE)) != arg0
+              && (code == EQ_EXPR || code == NE_EXPR
+                  || TREE_UNSIGNED (TREE_TYPE (arg0))
+                     == TREE_UNSIGNED (TREE_TYPE (tem)))
               && (t1 = get_unwidened (arg1, TREE_TYPE (tem))) != 0
               && (TREE_TYPE (t1) == TREE_TYPE (tem)
                   || (TREE_CODE (t1) == INTEGER_CST
index 359124c..c111369 100644 (file)
@@ -1,3 +1,8 @@
+2004-03-23  Roger Sayle  <roger@eyesopen.com>
+
+       PR optimization/14669
+       * g++.dg/opt/fold2.C: New test case.
+
 2004-03-22  Jakub Jelinek  <jakub@redhat.com>
 
        PR c/14069
diff --git a/gcc/testsuite/g++.dg/opt/fold2.C b/gcc/testsuite/g++.dg/opt/fold2.C
new file mode 100644 (file)
index 0000000..95063d7
--- /dev/null
@@ -0,0 +1,19 @@
+// PR optimization/14669
+// { dg-do run }
+// { dg-options "-O2" }
+
+extern "C" void abort (void);
+extern "C" void exit (int);
+
+enum ActionType { EE=-1, E0=0, E1, E2 };
+
+int main(void)
+{
+  ActionType t = E0;
+
+  if (E1 <= t && t <= E2)
+    abort ();
+
+  exit (0);
+}
+