diff options
author | kazu <kazu@138bc75d-0d04-0410-961f-82ee72b054a4> | 2003-04-17 21:42:19 +0000 |
---|---|---|
committer | kazu <kazu@138bc75d-0d04-0410-961f-82ee72b054a4> | 2003-04-17 21:42:19 +0000 |
commit | ed4ead76fec2cd562d2c0d7172aa5289bf3113ae (patch) | |
tree | ce5d2c9f1c930ffefdcebdac3891d91c22af277c /gcc | |
parent | f2f6bdab86a67e723520b8e831c287af9243a9ba (diff) | |
download | gcc-ed4ead76fec2cd562d2c0d7172aa5289bf3113ae.tar.gz |
* reload1.c (move2add_last_cc0): New.
(reload_cse_move2add): Detect implicit sets.
(move2add_note_store): Notice a store into cc0.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@65754 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/reload1.c | 34 |
2 files changed, 40 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 7beb2fc52a2..df58352d177 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2003-04-17 Kazu Hirata <kazu@cs.umass.edu> + + * reload1.c (move2add_last_cc0): New. + (reload_cse_move2add): Detect implicit sets. + (move2add_note_store): Notice a store into cc0. + 2003-04-17 Roger Sayle <roger@eyesopen.com> PR c/10375 diff --git a/gcc/reload1.c b/gcc/reload1.c index 54d163ee00c..83456130534 100644 --- a/gcc/reload1.c +++ b/gcc/reload1.c @@ -9094,6 +9094,9 @@ static int move2add_last_label_luid; && TRULY_NOOP_TRUNCATION (GET_MODE_BITSIZE (OUTMODE), \ GET_MODE_BITSIZE (INMODE)))) +/* The source of the last set to cc0 we've seen. */ +static rtx move2add_last_cc0; + static void reload_cse_move2add (first) rtx first; @@ -9106,6 +9109,7 @@ reload_cse_move2add (first) move2add_last_label_luid = 0; move2add_luid = 2; + move2add_last_cc0 = NULL_RTX; for (insn = first; insn; insn = NEXT_INSN (insn), move2add_luid++) { rtx pat, note; @@ -9288,6 +9292,29 @@ reload_cse_move2add (first) } } note_stores (PATTERN (insn), move2add_note_store, NULL); + + /* If INSN is a conditional branch, we try to extract an + implicit set out of it. */ + if (any_condjump_p (insn) && onlyjump_p (insn)) + { + rtx cnd = get_condition (insn, NULL); + +#ifdef HAVE_cc0 + if (cnd != NULL_RTX && move2add_last_cc0 != NULL_RTX) + cnd = simplify_replace_rtx (cnd, cc0_rtx, move2add_last_cc0); +#endif + if (cnd != NULL_RTX + && GET_CODE (cnd) == NE + && GET_CODE (XEXP (cnd, 0)) == REG + && SCALAR_INT_MODE_P (GET_MODE (XEXP (cnd, 0))) + && GET_CODE (XEXP (cnd, 1)) == CONST_INT) + { + rtx implicit_set = + gen_rtx_SET (VOIDmode, SET_DEST (cnd), SET_SRC (cnd)); + move2add_note_store (SET_DEST (implicit_set), implicit_set, 0); + } + } + /* If this is a CALL_INSN, all call used registers are stored with unknown values. */ if (GET_CODE (insn) == CALL_INSN) @@ -9334,6 +9361,13 @@ move2add_note_store (dst, set, data) reg_set_luid[REGNO (XEXP (dst, 0))] = 0; return; } + /* Note a store into cc0 so that we can later find an implicit + set. */ + if (CC0_P (dst)) + { + move2add_last_cc0 = SET_SRC (set); + return; + } if (GET_CODE (dst) != REG) return; |