aboutsummaryrefslogtreecommitdiff
path: root/gcc/reload.c
diff options
context:
space:
mode:
authorH.J. Lu <hongjiu.lu@intel.com>2007-11-06 19:19:23 +0000
committerH.J. Lu <hongjiu.lu@intel.com>2007-11-06 19:19:23 +0000
commitf1606b6065b77fe6eaad11ffe821a1cea6106a2a (patch)
tree4fc1509ee2ee17b510616af4d9fa98c1130c2a2b /gcc/reload.c
parent2be50280816ce3b0eeb222a2942636d740701be7 (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.c3
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));