diff options
author | amylaar <amylaar@138bc75d-0d04-0410-961f-82ee72b054a4> | 1998-07-07 13:09:07 +0000 |
---|---|---|
committer | amylaar <amylaar@138bc75d-0d04-0410-961f-82ee72b054a4> | 1998-07-07 13:09:07 +0000 |
commit | 05b1716f641576f8a060f89935c4bcfb56500195 (patch) | |
tree | 7cbde0f7b9d0cb95d7da7f00fc04eb7c6049068c /gcc/cse.c | |
parent | 1fa15c69f2b0eb9ad18f040a8d78dec065412664 (diff) | |
download | gcc-05b1716f641576f8a060f89935c4bcfb56500195.tar.gz |
* cse (cse_insn): Don't make change without validation.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@20996 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/cse.c')
-rw-r--r-- | gcc/cse.c | 29 |
1 files changed, 18 insertions, 11 deletions
diff --git a/gcc/cse.c b/gcc/cse.c index fd7b80bd8de..e34908f1680 100644 --- a/gcc/cse.c +++ b/gcc/cse.c @@ -7004,17 +7004,24 @@ cse_insn (insn, libcall_insn) SRC is a hard register. */ { int first = qty_first_reg[reg_qty[REGNO (src)]]; - - src = SET_SRC (sets[i].rtl) - = first >= FIRST_PSEUDO_REGISTER ? regno_reg_rtx[first] - : gen_rtx_REG (GET_MODE (src), first); - - /* If we had a constant that is cheaper than what we are now - setting SRC to, use that constant. We ignored it when we - thought we could make this into a no-op. */ - if (src_const && COST (src_const) < COST (src) - && validate_change (insn, &SET_SRC (sets[i].rtl), src_const, 0)) - src = src_const; + rtx new_src + = (first >= FIRST_PSEUDO_REGISTER + ? regno_reg_rtx[first] : gen_rtx_REG (GET_MODE (src), first)); + + /* We must use validate-change even for this, because this + might be a special no-op instruction, suitable only to + tag notes onto. */ + if (validate_change (insn, &SET_SRC (sets[i].rtl), new_src, 0)) + { + src = new_src; + /* If we had a constant that is cheaper than what we are now + setting SRC to, use that constant. We ignored it when we + thought we could make this into a no-op. */ + if (src_const && COST (src_const) < COST (src) + && validate_change (insn, &SET_SRC (sets[i].rtl), src_const, + 0)) + src = src_const; + } } /* If we made a change, recompute SRC values. */ |