From 00116a7b6d8aa3e10fb0fd09d3fd91c6584f9cdf Mon Sep 17 00:00:00 2001 From: Richard Henderson Date: Wed, 15 Jul 1998 18:22:41 -0600 Subject: [PATCH] loop.c (emit_iv_add_mult): Scan the entire insn list generated for the sequence, recording base values. 8 * loop.c (emit_iv_add_mult): Scan the entire insn list generated for the sequence, recording base values. From-SVN: r21208 --- gcc/loop.c | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/gcc/loop.c b/gcc/loop.c index 1932bdeb5bc..0171741e22b 100644 --- a/gcc/loop.c +++ b/gcc/loop.c @@ -6005,7 +6005,23 @@ emit_iv_add_mult (b, m, a, reg, insert_before) emit_insn_before (seq, insert_before); - record_base_value (REGNO (reg), b, 0); + /* It is entirely possible that the expansion created lots of new + registers. Iterate over the sequence we just created and + record them all. */ + + if (GET_CODE (seq) == SEQUENCE) + { + int i; + for (i = 0; i < XVECLEN (seq, 0); ++i) + { + rtx set = single_set (XVECEXP (seq, 0, i)); + if (set && GET_CODE (SET_DEST (set)) == REG) + record_base_value (REGNO (SET_DEST (set)), SET_SRC (set), 0); + } + } + else if (GET_CODE (seq) == SET + && GET_CODE (SET_DEST (seq)) == REG) + record_base_value (REGNO (SET_DEST (seq)), SET_SRC (seq), 0); } /* Test whether A * B can be computed without -- 2.30.2