OSDN Git Service

2006-10-11 Richard Guenther <rguenther@suse.de>
authorrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 11 Oct 2006 16:05:37 +0000 (16:05 +0000)
committerrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 11 Oct 2006 16:05:37 +0000 (16:05 +0000)
PR tree-optimization/28230
* tree-vrp.c (vrp_int_const_binop): Move flag_wrapv handling
to the correct place.

* gcc.dg/torture/pr28230.c: New testcase.

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

gcc/ChangeLog
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/torture/pr28230.c [new file with mode: 0644]
gcc/tree-vrp.c

index 8eca250..6fd39c7 100644 (file)
@@ -1,5 +1,11 @@
 2006-10-11  Richard Guenther  <rguenther@suse.de>
 
+       PR tree-optimization/28230
+       * tree-vrp.c (vrp_int_const_binop): Move flag_wrapv handling
+       to the correct place.
+
+2006-10-11  Richard Guenther  <rguenther@suse.de>
+
        PR inline-asm/29119
        * gimplify.c (gimplify_asm_expr): Mark the gimplified lvalue
        addressable.
index c9b7c54..aa9cd9e 100644 (file)
@@ -1,5 +1,10 @@
 2006-10-11  Richard Guenther  <rguenther@suse.de>
 
+       PR tree-optimization/28230
+       * gcc.dg/torture/pr28230.c: New testcase.
+
+2006-10-11  Richard Guenther  <rguenther@suse.de>
+
        PR inline-asm/29119
        * gcc.dg/torture/pr29119.c: New testcase.
 
diff --git a/gcc/testsuite/gcc.dg/torture/pr28230.c b/gcc/testsuite/gcc.dg/torture/pr28230.c
new file mode 100644 (file)
index 0000000..5ecc0c7
--- /dev/null
@@ -0,0 +1,20 @@
+/* { dg-do run } */
+/* { dg-options "-fwrapv" } */
+
+void foo( unsigned long long bb, unsigned short tn, unsigned e, unsigned* w );
+void foo( unsigned long long bb, unsigned short tn, unsigned e, unsigned* w )
+{
+        unsigned n = tn + bb;
+        do {
+                e = (e > n) ? e : *w;
+                n -= (e > n) ? n : e;
+                if (*w)
+                        *w = 0;
+        } while ( n );
+}
+int main()
+{
+        unsigned w = 0;
+        foo( 0, 0, 0, &w );
+        return 0;
+}
index a212744..4a30e4e 100644 (file)
@@ -1235,14 +1235,12 @@ vrp_int_const_binop (enum tree_code code, tree val1, tree val2)
 {
   tree res;
 
-  if (flag_wrapv)
-    return int_const_binop (code, val1, val2, 0);
+  res = int_const_binop (code, val1, val2, 0);
 
   /* If we are not using wrapping arithmetic, operate symbolically
      on -INF and +INF.  */
-  res = int_const_binop (code, val1, val2, 0);
-
-  if (TYPE_UNSIGNED (TREE_TYPE (val1)))
+  if (TYPE_UNSIGNED (TREE_TYPE (val1))
+      || flag_wrapv)
     {
       int checkz = compare_values (res, val1);
       bool overflow = false;