diff options
author | Steven Bosscher <steven@gcc.gnu.org> | 2007-02-20 22:14:41 +0000 |
---|---|---|
committer | Steven Bosscher <steven@gcc.gnu.org> | 2007-02-20 22:14:41 +0000 |
commit | 7cd689bcf045c55b1786cdbc84c9f63a07070a58 (patch) | |
tree | 86910b46650f770e82274e25d7d3f2c992409256 | |
parent | ea8f106d4c4e16933ef9bbd8bbd5a8588cd6c53f (diff) | |
download | gcc-7cd689bcf045c55b1786cdbc84c9f63a07070a58.zip gcc-7cd689bcf045c55b1786cdbc84c9f63a07070a58.tar.gz gcc-7cd689bcf045c55b1786cdbc84c9f63a07070a58.tar.bz2 |
rtl.h (remove_reg_equal_equiv_notes): New prototype.
* rtl.h (remove_reg_equal_equiv_notes): New prototype.
* rtlanal.c (remove_reg_equal_equiv_notes): New function.
* combine.c (adjust_for_new_dest): Use it.
* postreload.c (reload_combine): Likewise.
From-SVN: r122178
-rw-r--r-- | gcc/ChangeLog | 7 | ||||
-rw-r--r-- | gcc/combine.c | 12 | ||||
-rw-r--r-- | gcc/postreload.c | 11 | ||||
-rw-r--r-- | gcc/rtl.h | 1 | ||||
-rw-r--r-- | gcc/rtlanal.c | 18 |
5 files changed, 28 insertions, 21 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index cbb93b7..0be8ba5 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,12 @@ 2007-02-20 Steven Bosscher <steven@gcc.gnu.org> + * rtl.h (remove_reg_equal_equiv_notes): New prototype. + * rtlanal.c (remove_reg_equal_equiv_notes): New function. + * combine.c (adjust_for_new_dest): Use it. + * postreload.c (reload_combine): Likewise. + +2007-02-20 Steven Bosscher <steven@gcc.gnu.org> + * rtlanal.c (find_reg_equal_equiv_note): Do not find REG_EQ* notes on an insn with multiple sets, even if single_set returns non-NULL for that insn. diff --git a/gcc/combine.c b/gcc/combine.c index 6605b7a..d1277d4 100644 --- a/gcc/combine.c +++ b/gcc/combine.c @@ -1726,18 +1726,8 @@ likely_spilled_retval_p (rtx insn) static void adjust_for_new_dest (rtx insn) { - rtx *loc; - /* For notes, be conservative and simply remove them. */ - loc = ®_NOTES (insn); - while (*loc) - { - enum reg_note kind = REG_NOTE_KIND (*loc); - if (kind == REG_EQUAL || kind == REG_EQUIV) - *loc = XEXP (*loc, 1); - else - loc = &XEXP (*loc, 1); - } + remove_reg_equal_equiv_notes (insn); /* The new insn will have a destination that was previously the destination of an insn just above it. Call distribute_links to make a LOG_LINK from diff --git a/gcc/postreload.c b/gcc/postreload.c index d1e58ab..47930ad 100644 --- a/gcc/postreload.c +++ b/gcc/postreload.c @@ -887,22 +887,13 @@ reload_combine (void) if (apply_change_group ()) { - rtx *np; - /* Delete the reg-reg addition. */ delete_insn (insn); if (reg_state[regno].offset != const0_rtx) /* Previous REG_EQUIV / REG_EQUAL notes for PREV are now invalid. */ - for (np = ®_NOTES (prev); *np;) - { - if (REG_NOTE_KIND (*np) == REG_EQUAL - || REG_NOTE_KIND (*np) == REG_EQUIV) - *np = XEXP (*np, 1); - else - np = &XEXP (*np, 1); - } + remove_reg_equal_equiv_notes (prev); reg_state[regno].use_index = RELOAD_COMBINE_MAX_USES; reg_state[REGNO (const_reg)].store_ruid @@ -1702,6 +1702,7 @@ extern int find_reg_fusage (rtx, enum rtx_code, rtx); extern int find_regno_fusage (rtx, enum rtx_code, unsigned int); extern int pure_call_p (rtx); extern void remove_note (rtx, rtx); +extern void remove_reg_equal_equiv_notes (rtx); extern int side_effects_p (rtx); extern int volatile_refs_p (rtx); extern int volatile_insn_p (rtx); diff --git a/gcc/rtlanal.c b/gcc/rtlanal.c index b23eec4..00a996e 100644 --- a/gcc/rtlanal.c +++ b/gcc/rtlanal.c @@ -1820,6 +1820,24 @@ remove_note (rtx insn, rtx note) gcc_unreachable (); } +/* Remove REG_EQUAL and/or REG_EQUIV notes if INSN has such notes. */ + +void +remove_reg_equal_equiv_notes (rtx insn) +{ + rtx *loc; + + loc = ®_NOTES (insn); + while (*loc) + { + enum reg_note kind = REG_NOTE_KIND (*loc); + if (kind == REG_EQUAL || kind == REG_EQUIV) + *loc = XEXP (*loc, 1); + else + loc = &XEXP (*loc, 1); + } +} + /* Search LISTP (an EXPR_LIST) for an entry whose first operand is NODE and return 1 if it is found. A simple equality test is used to determine if NODE matches. */ |