aboutsummaryrefslogtreecommitdiff
path: root/gcc/regrename.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2002-03-25 08:45:30 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2002-03-25 08:45:30 +0100
commitea475b235ec7829172dc72ab4422e6b3a401c265 (patch)
tree863527e50b8f256b7731c19a867bbf1f242bfe65 /gcc/regrename.c
parent9b95cee697dd90a4a01902b5ded4ff8133b02f32 (diff)
downloadgcc-ea475b235ec7829172dc72ab4422e6b3a401c265.zip
gcc-ea475b235ec7829172dc72ab4422e6b3a401c265.tar.gz
gcc-ea475b235ec7829172dc72ab4422e6b3a401c265.tar.bz2
regrename.c (build_def_use): Share RTL between MATCH_OPERATOR and corresponding MATCH_DUP.
* regrename.c (build_def_use): Share RTL between MATCH_OPERATOR and corresponding MATCH_DUP. * gcc.c-torture/compile/20020323-1.c: New test. From-SVN: r51305
Diffstat (limited to 'gcc/regrename.c')
-rw-r--r--gcc/regrename.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/gcc/regrename.c b/gcc/regrename.c
index 6277398..448eeb8 100644
--- a/gcc/regrename.c
+++ b/gcc/regrename.c
@@ -764,7 +764,7 @@ build_def_use (bb)
rtx note;
rtx old_operands[MAX_RECOG_OPERANDS];
rtx old_dups[MAX_DUP_OPERANDS];
- int i;
+ int i, icode;
int alt;
int predicated;
@@ -786,6 +786,7 @@ build_def_use (bb)
extract_insn (insn);
constrain_operands (1);
+ icode = recog_memoized (insn);
preprocess_constraints ();
alt = which_alternative;
n_ops = recog_data.n_operands;
@@ -827,8 +828,16 @@ build_def_use (bb)
}
for (i = 0; i < recog_data.n_dups; i++)
{
+ int dup_num = recog_data.dup_num[i];
+
old_dups[i] = *recog_data.dup_loc[i];
*recog_data.dup_loc[i] = cc0_rtx;
+
+ /* For match_dup of match_operator or match_parallel, share
+ them, so that we don't miss changes in the dup. */
+ if (icode >= 0
+ && insn_data[icode].operand[dup_num].eliminable == 0)
+ old_dups[i] = recog_data.operand[dup_num];
}
scan_rtx (insn, &PATTERN (insn), NO_REGS, terminate_all_read,