aboutsummaryrefslogtreecommitdiff
path: root/gcc/reload.c
diff options
context:
space:
mode:
authorH.J. Lu <hjl@gcc.gnu.org>2007-11-06 11:19:23 -0800
committerH.J. Lu <hjl@gcc.gnu.org>2007-11-06 11:19:23 -0800
commitb3519e7c8a1c3822a3f5ad2a861ffeae45bf98cb (patch)
tree4fc1509ee2ee17b510616af4d9fa98c1130c2a2b /gcc/reload.c
parentb8c963204c1d408b202e17dd58ee56c5b8e27d30 (diff)
downloadgcc-b3519e7c8a1c3822a3f5ad2a861ffeae45bf98cb.zip
gcc-b3519e7c8a1c3822a3f5ad2a861ffeae45bf98cb.tar.gz
gcc-b3519e7c8a1c3822a3f5ad2a861ffeae45bf98cb.tar.bz2
re PR target/30961 (redundant reg/mem stores/moves)
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. From-SVN: r129943
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 c9c5fc5..871f171 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));