From: Richard Biener Date: Fri, 19 May 2017 08:23:37 +0000 (+0000) Subject: re PR middle-end/80764 (ICE at -O3 in both 32-bit and 64-bit modes on x86_64-linux... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=035ab82621cd702bb7fc566ca7ccbcb6a9567058;p=gcc.git re PR middle-end/80764 (ICE at -O3 in both 32-bit and 64-bit modes on x86_64-linux-gnu (internal compiler error: in verify_loop_structure, at cfgloop.c:1644)) 2017-05-19 Richard Biener PR middle-end/80764 * cfgexpand.c (expand_gimple_cond): Fix loop fixup. * gcc.dg/torture/pr80764.c: New testcase. From-SVN: r248261 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 23f9b69074b..aae3fdded7e 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2017-05-19 Richard Biener + + PR middle-end/80764 + * cfgexpand.c (expand_gimple_cond): Fix loop fixup. + 2017-05-18 Segher Boessenkool * config/rs6000/rs6000.c (struct machine_function): Add field diff --git a/gcc/cfgexpand.c b/gcc/cfgexpand.c index e38c8e4ac49..9965310353e 100644 --- a/gcc/cfgexpand.c +++ b/gcc/cfgexpand.c @@ -2503,7 +2503,10 @@ expand_gimple_cond (basic_block bb, gcond *stmt) false_edge->flags |= EDGE_FALLTHRU; new_bb->count = false_edge->count; new_bb->frequency = EDGE_FREQUENCY (false_edge); - add_bb_to_loop (new_bb, bb->loop_father); + add_bb_to_loop (new_bb, dest->loop_father); + if (bb->loop_father->latch == bb + && bb->loop_father->header == dest) + bb->loop_father->latch = new_bb; new_edge = make_edge (new_bb, dest, 0); new_edge->probability = REG_BR_PROB_BASE; new_edge->count = new_bb->count; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index c785b02e211..29a19ccbf2a 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2017-05-19 Richard Biener + + PR middle-end/80764 + * gcc.dg/torture/pr80764.c: New testcase. + 2017-05-18 Michael Meissner PR target/80510 diff --git a/gcc/testsuite/gcc.dg/torture/pr80764.c b/gcc/testsuite/gcc.dg/torture/pr80764.c new file mode 100644 index 00000000000..bc6d8e87ac3 --- /dev/null +++ b/gcc/testsuite/gcc.dg/torture/pr80764.c @@ -0,0 +1,14 @@ +/* { dg-do compile } */ + +int b, d, f, h; +char e; +int fn1(); +int main() { return fn1(); } +int fn1(int p1) { + for (; d;) + for (; e < 3;) { + for (; h;) + b = fn1(0); + return f; + } +}