From: Richard Henderson Date: Thu, 16 Jul 1998 00:22:41 +0000 (-0600) Subject: loop.c (emit_iv_add_mult): Scan the entire insn list generated for the sequence,... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=00116a7b6d8aa3e10fb0fd09d3fd91c6584f9cdf;p=gcc.git 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 --- 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