From: Jakub Jelinek Date: Fri, 12 Nov 2010 11:28:32 +0000 (+0100) Subject: backport: re PR tree-optimization/46107 (-ftree-loop-distribute-patterns caused verif... X-Git-Tag: releases/gcc-4.4.6~270 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=bc1345169a2f2a7f3d95c0753b474b014c3bc830;p=thirdparty%2Fgcc.git backport: re PR tree-optimization/46107 (-ftree-loop-distribute-patterns caused verify_loop_structure problem) Backport from mainline 2010-11-03 Jakub Jelinek PR tree-optimization/46107 * cfgloopmanip.c (loop_version): Set irred_flag back into entry->flags if cfg_hook_duplicate_loop_to_header_edge failed. * gcc.c-torture/compile/pr46107.c: New test. From-SVN: r166649 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 8c766dea7bb5..bd022e95b4ae 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,12 @@ +2010-11-12 Jakub Jelinek + + Backport from mainline + 2010-11-03 Jakub Jelinek + + PR tree-optimization/46107 + * cfgloopmanip.c (loop_version): Set irred_flag back into entry->flags + if cfg_hook_duplicate_loop_to_header_edge failed. + 2010-11-10 Uros Bizjak PR middle-end/46419 diff --git a/gcc/cfgloopmanip.c b/gcc/cfgloopmanip.c index 28cfa3cfc9aa..267eb8f183c3 100644 --- a/gcc/cfgloopmanip.c +++ b/gcc/cfgloopmanip.c @@ -1546,7 +1546,10 @@ loop_version (struct loop *loop, /* Duplicate loop. */ if (!cfg_hook_duplicate_loop_to_header_edge (loop, entry, 1, NULL, NULL, NULL, 0)) - return NULL; + { + entry->flags |= irred_flag; + return NULL; + } /* After duplication entry edge now points to new loop head block. Note down new head as second_head. */ diff --git a/gcc/gimplify.c b/gcc/gimplify.c index ea4f26d54569..94bae9c83f2c 100644 --- a/gcc/gimplify.c +++ b/gcc/gimplify.c @@ -4842,6 +4842,13 @@ gimplify_asm_expr (tree *expr_p, gimple_seq *pre_p, gimple_seq *post_p) /* If the operand is a memory input, it should be an lvalue. */ if (!allows_reg && allows_mem) { + tree inputv = TREE_VALUE (link); + STRIP_NOPS (inputv); + if (TREE_CODE (inputv) == PREDECREMENT_EXPR + || TREE_CODE (inputv) == PREINCREMENT_EXPR + || TREE_CODE (inputv) == POSTDECREMENT_EXPR + || TREE_CODE (inputv) == POSTINCREMENT_EXPR) + TREE_VALUE (link) = error_mark_node; tret = gimplify_expr (&TREE_VALUE (link), pre_p, post_p, is_gimple_lvalue, fb_lvalue | fb_mayfail); mark_addressable (TREE_VALUE (link)); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 12da78f95b13..be2b2c0ea0a4 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,11 @@ +2010-11-12 Jakub Jelinek + + Backport from mainline + 2010-11-03 Jakub Jelinek + + PR tree-optimization/46107 + * gcc.c-torture/compile/pr46107.c: New test. + 2010-11-10 Uros Bizjak PR target/46419 diff --git a/gcc/testsuite/gcc.c-torture/compile/pr46107.c b/gcc/testsuite/gcc.c-torture/compile/pr46107.c new file mode 100644 index 000000000000..41582b8a161a --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/compile/pr46107.c @@ -0,0 +1,16 @@ +/* PR tree-optimization/46107 */ + +int foo (void) __attribute__ ((noreturn)); + +void +bar (int x, int *y, int z) +{ + static void *j[] = { &&l1, &&l2 }; +l1: + if (*y) + goto *j[z]; + foo (); +l2: + *y ^= (x & 1) ? -1 : 0; + goto *j[x]; +}