diff options
author | Jeff Law <law@redhat.com> | 2020-05-31 11:16:37 -0600 |
---|---|---|
committer | Jeff Law <law@redhat.com> | 2020-05-31 11:18:15 -0600 |
commit | c25d0fa4d76cbc46078624d101ac019ff3df1142 (patch) | |
tree | 891b08fcc93545e2d2a8d02ad1c402c76a544dcf /gcc/rtlanal.c | |
parent | 05430b9b6a7c4aeaab595787ac1fbf6f3e0196a0 (diff) |
Fix execute/20071219-1.c regression on H8 due to loss of REG_INC notes in peephole2.
gcc/
* lra.c (add_auto_inc_notes): Remove function.
* reload1.c (add_auto_inc_notes): Similarly. Move into...
* rtlanal.c (add_auto_inc_notes): New function.
* rtl.h (add_auto_inc_notes): Add prototype.
* recog.c (peep2_attempt): Scan and add REG_INC notes to new insns
as needed.
Diffstat (limited to 'gcc/rtlanal.c')
-rw-r--r-- | gcc/rtlanal.c | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/gcc/rtlanal.c b/gcc/rtlanal.c index 9ff17caaba0..1d2874d8672 100644 --- a/gcc/rtlanal.c +++ b/gcc/rtlanal.c @@ -6591,3 +6591,29 @@ tls_referenced_p (const_rtx x) return true; return false; } + +/* Process recursively X of INSN and add REG_INC notes if necessary. */ +void +add_auto_inc_notes (rtx_insn *insn, rtx x) +{ + enum rtx_code code = GET_CODE (x); + const char *fmt; + int i, j; + + if (code == MEM && auto_inc_p (XEXP (x, 0))) + { + add_reg_note (insn, REG_INC, XEXP (XEXP (x, 0), 0)); + return; + } + + /* Scan all X sub-expressions. */ + fmt = GET_RTX_FORMAT (code); + for (i = GET_RTX_LENGTH (code) - 1; i >= 0; i--) + { + if (fmt[i] == 'e') + add_auto_inc_notes (insn, XEXP (x, i)); + else if (fmt[i] == 'E') + for (j = XVECLEN (x, i) - 1; j >= 0; j--) + add_auto_inc_notes (insn, XVECEXP (x, i, j)); + } +} |