diff options
author | H.J. Lu <hongjiu.lu@intel.com> | 2007-11-06 19:19:23 +0000 |
---|---|---|
committer | H.J. Lu <hongjiu.lu@intel.com> | 2007-11-06 19:19:23 +0000 |
commit | f1606b6065b77fe6eaad11ffe821a1cea6106a2a (patch) | |
tree | 4fc1509ee2ee17b510616af4d9fa98c1130c2a2b /gcc/reload.c | |
parent | 2be50280816ce3b0eeb222a2942636d740701be7 (diff) |
gcc/
2007-11-06 Ulrich Weigand <Ulrich.Weigand@de.ibm.com>
PR target/30961
* reload1.c (find_reloads): Also check in_reg when handling a
simple move with an input reload and a destination of a hard
register.
gcc/testsuite/
2007-11-06 H.J. Lu <hongjiu.lu@intel.com>
PR target/30961
* gcc.target/i386/pr30961-1.c: New.
git-svn-id: https://gcc.gnu.org/svn/gcc/trunk@129943 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/reload.c')
-rw-r--r-- | gcc/reload.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/gcc/reload.c b/gcc/reload.c index c9c5fc5c5c0..871f1718301 100644 --- a/gcc/reload.c +++ b/gcc/reload.c @@ -4462,7 +4462,8 @@ find_reloads (rtx insn, int replace, int ind_levels, int live_known, if (rld[i].when_needed == RELOAD_FOR_INPUT && GET_CODE (PATTERN (insn)) == SET && REG_P (SET_DEST (PATTERN (insn))) - && SET_SRC (PATTERN (insn)) == rld[i].in + && (SET_SRC (PATTERN (insn)) == rld[i].in + || SET_SRC (PATTERN (insn)) == rld[i].in_reg) && !elimination_target_reg_p (SET_DEST (PATTERN (insn)))) { rtx dest = SET_DEST (PATTERN (insn)); |