From: Richard Biener Date: Mon, 25 Mar 2013 12:54:56 +0000 (+0000) Subject: re PR bootstrap/56689 (internal compiler error: in get_loop_body, at cfgloop.c:841) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=051b94466891c0eedaf808be384fa8696a680380;p=gcc.git re PR bootstrap/56689 (internal compiler error: in get_loop_body, at cfgloop.c:841) 2013-03-25 Richard Biener PR tree-optimization/56689 * tree-vrp.c (execute_vrp): Mark loops for fixup if we removed any edge. * gcc.dg/torture/pr56689.c: New testcase. From-SVN: r197039 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 3abf8781e7d..3db3f1d36d3 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2013-03-25 Richard Biener + + PR tree-optimization/56689 + * tree-vrp.c (execute_vrp): Mark loops for fixup if we removed + any edge. + 2013-03-25 Richard Biener * tree-ssa-loop-im.c (struct mem_ref): Use bitmap_head instead diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 0a389fc18ef..2aad75a8e34 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2013-03-25 Richard Biener + + PR tree-optimization/56689 + * gcc.dg/torture/pr56689.c: New testcase. + 2013-03-25 Kai Tietz * g++.dg/torture/20121105-1.C: Adjust for LLP64 targets. diff --git a/gcc/testsuite/gcc.dg/torture/pr56689.c b/gcc/testsuite/gcc.dg/torture/pr56689.c new file mode 100644 index 00000000000..719f528c2c0 --- /dev/null +++ b/gcc/testsuite/gcc.dg/torture/pr56689.c @@ -0,0 +1,46 @@ +/* { dg-do compile } */ + +extern int baz (); +extern void bar (void); +extern void noret (void) __attribute__ ((__noreturn__)); + +void +fix_register (const char *name, int fixed, int call_used, int nregs) +{ + int i; + int reg; + + if ((reg = baz ()) >= 0) + { + for (i = reg; i < nregs; i++) + { + if ((i == 15 || i == 11) && (fixed == 0 || call_used == 0)) + { + switch (fixed) + { + case 0: + switch (call_used) + { + case 1: + bar (); + break; + default: + (noret ()); + } + case 1: + switch (call_used) + { + case 1: + break; + case 0: + default: + (noret ()); + } + break; + default: + (noret ()); + } + } + } + } +} diff --git a/gcc/tree-vrp.c b/gcc/tree-vrp.c index a38b14d4956..250a5063136 100644 --- a/gcc/tree-vrp.c +++ b/gcc/tree-vrp.c @@ -9329,7 +9329,11 @@ execute_vrp (void) } if (to_remove_edges.length () > 0) - free_dominance_info (CDI_DOMINATORS); + { + free_dominance_info (CDI_DOMINATORS); + if (current_loops) + loops_state_set (LOOPS_NEED_FIXUP); + } to_remove_edges.release (); to_update_switch_stmts.release ();