mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-04-04 19:11:19 +08:00
cfgcleanup.c (flow_find_cross_jump): Delete any REG_EQUAL notes that would be invalid after a merge.
* cfgcleanup.c (flow_find_cross_jump): Delete any REG_EQUAL notes that would be invalid after a merge. From-SVN: r45727
This commit is contained in:
parent
53c170316f
commit
7106d49104
@ -1,3 +1,8 @@
|
||||
21-09-2001 Richard Earnshaw (reanrsha@arm.com)
|
||||
|
||||
* cfgcleanup.c (flow_find_cross_jump): Delete any REG_EQUAL notes
|
||||
that would be invalid after a merge.
|
||||
|
||||
Fri Sep 21 14:24:29 CEST 2001 Jan Hubicka <jh@suse.cz>
|
||||
|
||||
* basic-block.h (flow_delete_insn, flow_delete_insn_chain): Kill.
|
||||
|
@ -583,6 +583,22 @@ flow_find_cross_jump (mode, bb1, bb2, f1, f2)
|
||||
/* Don't begin a cross-jump with a USE or CLOBBER insn. */
|
||||
if (GET_CODE (p1) != USE && GET_CODE (p1) != CLOBBER)
|
||||
{
|
||||
/* If the merged insns have different REG_EQUAL notes, then
|
||||
remove them. */
|
||||
rtx equiv1 = find_reg_equal_equiv_note (i1);
|
||||
rtx equiv2 = find_reg_equal_equiv_note (i2);
|
||||
|
||||
if (equiv1 && !equiv2)
|
||||
remove_note (i1, equiv1);
|
||||
else if (!equiv1 && equiv2)
|
||||
remove_note (i2, equiv2);
|
||||
else if (equiv1 && equiv2
|
||||
&& !rtx_equal_p (XEXP (equiv1, 0), XEXP (equiv2, 0)))
|
||||
{
|
||||
remove_note (i1, equiv1);
|
||||
remove_note (i2, equiv2);
|
||||
}
|
||||
|
||||
afterlast1 = last1, afterlast2 = last2;
|
||||
last1 = i1, last2 = i2;
|
||||
ninsns++;
|
||||
|
Loading…
x
Reference in New Issue
Block a user