From: rsandifo Date: Tue, 30 Jan 2007 15:07:34 +0000 (+0000) Subject: gcc/ X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=3d5a3e764e0ab7c5873690d25c6c4679134f9ac7;p=thirdparty%2Fgcc.git gcc/ * cfgrtl.c (try_redirect_by_replacing_jump): Check only_sets_cc0_p. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@121339 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index cc300099d60c..fa3cf11d4ca1 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,7 @@ +2007-01-30 Richard Sandiford + + * cfgrtl.c (try_redirect_by_replacing_jump): Check only_sets_cc0_p. + 2007-01-30 Uros Bizjak * builtins.c (expand_builtin_int_interclass_roundingfn): New function diff --git a/gcc/cfgrtl.c b/gcc/cfgrtl.c index 4aaedbe47243..44246210e60a 100644 --- a/gcc/cfgrtl.c +++ b/gcc/cfgrtl.c @@ -728,7 +728,8 @@ try_redirect_by_replacing_jump (edge e, basic_block target, bool in_cfglayout) the cc0 setter too. */ kill_from = insn; #ifdef HAVE_cc0 - if (reg_mentioned_p (cc0_rtx, PATTERN (insn))) + if (reg_mentioned_p (cc0_rtx, PATTERN (insn)) + && only_sets_cc0_p (PREV_INSN (insn))) kill_from = PREV_INSN (insn); #endif