re PR tree-optimization/55236 (gcc.c-torture/execute/pr22493-1.c FAILs with -fPIC)
authorJakub Jelinek <jakub@redhat.com>
Sat, 17 Nov 2012 22:00:32 +0000 (23:00 +0100)
committerJakub Jelinek <jakub@gcc.gnu.org>
Sat, 17 Nov 2012 22:00:32 +0000 (23:00 +0100)
PR tree-optimization/55236
* fold-const.c (make_range_step) <case NEGATE_EXPR>: For -fwrapv
and signed ARG0_TYPE, force low and high to be non-NULL.

* gcc.dg/pr55236.c: New test.

From-SVN: r193591

gcc/ChangeLog
gcc/fold-const.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/pr55236.c [new file with mode: 0644]

index eb01532..935e3c0 100644 (file)
@@ -1,3 +1,9 @@
+2012-11-17  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/55236
+       * fold-const.c (make_range_step) <case NEGATE_EXPR>: For -fwrapv
+       and signed ARG0_TYPE, force low and high to be non-NULL.
+
 2012-11-17  H.J. Lu  <hongjiu.lu@intel.com>
 
        * common.opt (static-libasan): New option.
index 2e90864..56e0554 100644 (file)
@@ -3880,6 +3880,17 @@ make_range_step (location_t loc, enum tree_code code, tree arg0, tree arg1,
       return arg0;
 
     case NEGATE_EXPR:
+      /* If flag_wrapv and ARG0_TYPE is signed, make sure
+        low and high are non-NULL, then normalize will DTRT.  */
+      if (!TYPE_UNSIGNED (arg0_type)
+         && !TYPE_OVERFLOW_UNDEFINED (arg0_type))
+       {
+         if (low == NULL_TREE)
+           low = TYPE_MIN_VALUE (arg0_type);
+         if (high == NULL_TREE)
+           high = TYPE_MAX_VALUE (arg0_type);
+       }
+
       /* (-x) IN [a,b] -> x in [-b, -a]  */
       n_low = range_binop (MINUS_EXPR, exp_type,
                           build_int_cst (exp_type, 0),
index 955546e..245b6ef 100644 (file)
@@ -1,5 +1,8 @@
 2012-11-17  Jakub Jelinek  <jakub@redhat.com>
 
+       PR tree-optimization/55236
+       * gcc.dg/pr55236.c: New test.
+
        PR testsuite/55188
        * gcc.dg/pr19105.c: Accept also optimizing
        -[2, 2] and -[3, 3] and -[4, 4] range tests together.
diff --git a/gcc/testsuite/gcc.dg/pr55236.c b/gcc/testsuite/gcc.dg/pr55236.c
new file mode 100644 (file)
index 0000000..dc66c04
--- /dev/null
@@ -0,0 +1,31 @@
+/* PR tree-optimization/55236 */
+/* { dg-do run } */
+/* { dg-options "-O2 -fwrapv" } */
+
+extern void abort ();
+
+__attribute__((noinline, noclone)) void
+foo (int i)
+{
+  if (i > 0)
+    abort ();
+  i = -i;
+  if (i < 0)
+    return;
+  abort ();
+}
+
+__attribute__((noinline, noclone)) void
+bar (int i)
+{
+  if (i > 0 || (-i) >= 0)
+    abort ();
+}
+
+int
+main ()
+{
+  foo (-__INT_MAX__ - 1);
+  bar (-__INT_MAX__ - 1);
+  return 0;
+}