From: Richard Biener Date: Tue, 16 Feb 2016 10:53:08 +0000 (+0000) Subject: re PR rtl-optimization/69291 (wrong code at -O1 for ruby-2.3.0/regcomp.c:985:compile_... X-Git-Tag: basepoints/gcc-7~926 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=d5b1a52eec591a9a995e47880c87333b42ebb870;p=thirdparty%2Fgcc.git re PR rtl-optimization/69291 (wrong code at -O1 for ruby-2.3.0/regcomp.c:985:compile_length_quantifier_node()) 2016-02-16 Richard Biener PR rtl-optimization/69291 * ifcvt.c (noce_try_store_flag_constants): Re-instantiate noce_operand_ok check. From-SVN: r233448 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index b746a4f9263e..a00388cafe6b 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2016-02-16 Richard Biener + + PR rtl-optimization/69291 + * ifcvt.c (noce_try_store_flag_constants): Re-instantiate + noce_operand_ok check. + 2016-02-16 Tom de Vries PR lto/67709 diff --git a/gcc/ifcvt.c b/gcc/ifcvt.c index 205590938a5e..4949965c9dc7 100644 --- a/gcc/ifcvt.c +++ b/gcc/ifcvt.c @@ -1277,7 +1277,8 @@ noce_try_store_flag_constants (struct noce_if_info *if_info) /* Allow expressions that are not using the result or plain registers where we handle overlap below. */ && (REG_P (XEXP (a, 0)) - || ! reg_overlap_mentioned_p (if_info->x, XEXP (a, 0))) + || (noce_operand_ok (XEXP (a, 0)) + && ! reg_overlap_mentioned_p (if_info->x, XEXP (a, 0)))) && if_info->branch_cost >= 2) { common = XEXP (a, 0);