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
+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
+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
--- /dev/null
+/* { 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;
+}
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);
struct loop *loop;
bool changed = false;
unsigned todo = 0;
+ basic_block bb;
if (number_of_loops () <= 1)
return 0;
free_dominance_info (CDI_POST_DOMINATORS);
+#ifdef ENABLE_CHECKING
+ FOR_EACH_BB (bb)
+ gcc_assert (!bb->aux);
+#endif
+
return todo;
}