re PR tree-optimization/53070 (ICE: in execute_cse_reciprocals, at tree-ssa-math...
authorRichard Guenther <rguenther@suse.de>
Mon, 23 Apr 2012 12:47:02 +0000 (12:47 +0000)
committerRichard Biener <rguenth@gcc.gnu.org>
Mon, 23 Apr 2012 12:47:02 +0000 (12:47 +0000)
2012-04-23  Richard Guenther  <rguenther@suse.de>

PR tree-optimization/53070
* tree-if-conv.c (combine_blocks): Free predicates in all blocks.
(main_tree_if_conversion): Verify we succeeded in that.

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

From-SVN: r186704

gcc/ChangeLog
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/torture/pr53070.c [new file with mode: 0644]
gcc/tree-if-conv.c

index f1fca143c402fb21a9702cc5a743171ed3be5de1..06a315812c3a2e3764679b9ecfb6389bb3d11cb2 100644 (file)
@@ -1,3 +1,9 @@
+2012-04-23  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/53070
+       * tree-if-conv.c (combine_blocks): Free predicates in all blocks.
+       (main_tree_if_conversion): Verify we succeeded in that.
+
 2012-04-23  Jan Hubicka  <jh@suse.cz>
 
        * lto-symtab.c (lto_cgraph_replace_node): Do not call
index 7843587d772e7dec242ec11480e73ecc8a979f6c..ac080621442933e7c270e49a98147f238adf54d6 100644 (file)
@@ -1,3 +1,8 @@
+2012-04-23  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/53070
+       * gcc.dg/torture/pr53070.c: New testcase.
+
 2012-04-23  Richard Guenther  <rguenther@suse.de>
 
        PR c/53060
diff --git a/gcc/testsuite/gcc.dg/torture/pr53070.c b/gcc/testsuite/gcc.dg/torture/pr53070.c
new file mode 100644 (file)
index 0000000..534ac34
--- /dev/null
@@ -0,0 +1,10 @@
+/* { dg-do compile } */
+/* { dg-options "-ffast-math -ftree-loop-if-convert -fno-tree-loop-im" } */
+int
+foo (int c)
+{
+  int t = 0, i = 0;
+  for (; i < 100; i++)
+    t += c ? c : 1;
+  return t;
+}
index 31bb610af08c44617fa9ea1a6d70dd5b17f9bf9d..d8e23a43672e91c3dfa9cc290b501a2b0a0990e4 100644 (file)
@@ -1651,8 +1651,8 @@ combine_blocks (struct loop *loop)
       free_bb_predicate (bb);
       if (bb_with_exit_edge_p (loop, bb))
        {
+         gcc_assert (exit_bb == NULL);
          exit_bb = bb;
-         break;
        }
     }
   gcc_assert (exit_bb != loop->latch);
@@ -1779,6 +1779,7 @@ main_tree_if_conversion (void)
   struct loop *loop;
   bool changed = false;
   unsigned todo = 0;
+  basic_block bb;
 
   if (number_of_loops () <= 1)
     return 0;
@@ -1794,6 +1795,11 @@ main_tree_if_conversion (void)
 
   free_dominance_info (CDI_POST_DOMINATORS);
 
+#ifdef ENABLE_CHECKING
+  FOR_EACH_BB (bb)
+    gcc_assert (!bb->aux);
+#endif
+
   return todo;
 }