From 52c1d580dd2a0bb42d4abd8cbf58840c2921b28f Mon Sep 17 00:00:00 2001 From: Bernd Schmidt Date: Sat, 10 Apr 2010 12:33:17 +0000 Subject: [PATCH] reload1.c (eliminate_regs_in_insn): Don't restore an operand if doing so would replace the entire pattern. * reload1.c (eliminate_regs_in_insn): Don't restore an operand if doing so would replace the entire pattern. From-SVN: r158188 --- gcc/ChangeLog | 3 +++ gcc/reload1.c | 5 ++++- 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 5b2f0f05fbb..ed09c30850a 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -9,6 +9,9 @@ (web_main): Call it. (union_defs): Don't try to recognize match_dups. + * reload1.c (eliminate_regs_in_insn): Don't restore an operand + if doing so would replace the entire pattern. + 2010-04-09 Uros Bizjak PR target/43707 diff --git a/gcc/reload1.c b/gcc/reload1.c index 02fef2d9eae..bd590cbc9c9 100644 --- a/gcc/reload1.c +++ b/gcc/reload1.c @@ -3557,7 +3557,10 @@ eliminate_regs_in_insn (rtx insn, int replace) { /* Restore the old body. */ for (i = 0; i < recog_data.n_operands; i++) - *recog_data.operand_loc[i] = orig_operand[i]; + /* Restoring a top-level match_parallel would clobber the new_body + we installed in the insn. */ + if (recog_data.operand_loc[i] != &PATTERN (insn)) + *recog_data.operand_loc[i] = orig_operand[i]; for (i = 0; i < recog_data.n_dups; i++) *recog_data.dup_loc[i] = orig_operand[(int) recog_data.dup_num[i]]; } -- 2.30.2