From: J"orn Rennecke Date: Wed, 16 Sep 1998 06:49:57 +0000 (+0000) Subject: regmove.c (copy_src_to_dest): Don't copy if that requires (a) new register(s). X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=1a8fca8acca89b7f57c3d855eda0a545d8b3ec42;p=gcc.git regmove.c (copy_src_to_dest): Don't copy if that requires (a) new register(s). * regmove.c (copy_src_to_dest): Don't copy if that requires (a) new register(s). From-SVN: r22448 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index ddb36b31295..dcd0e882b0e 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +Wed Sep 16 14:47:43 1998 J"orn Rennecke + + * regmove.c (copy_src_to_dest): Don't copy if that requires + (a) new register(s). + Wed Sep 16 01:29:12 1998 Bernd Schmidt * global.c (reg_allocno): Now static. diff --git a/gcc/regmove.c b/gcc/regmove.c index 8df75e5c8aa..d8dec1faed0 100644 --- a/gcc/regmove.c +++ b/gcc/regmove.c @@ -617,14 +617,25 @@ copy_src_to_dest (insn, src, dest, loop_depth) && GET_CODE (dest) == REG && REG_LIVE_LENGTH (REGNO (dest)) > 0 && (set = single_set (insn)) != NULL_RTX - && !reg_mentioned_p (dest, SET_SRC (set)) - && validate_replace_rtx (src, dest, insn)) + && !reg_mentioned_p (dest, SET_SRC (set))) { + int old_num_regs = reg_rtx_no; + /* Generate the src->dest move. */ start_sequence (); emit_move_insn (dest, src); seq = gen_sequence (); end_sequence (); + /* If this sequence uses new registers, we may not use it. */ + if (old_num_regs != reg_rtx_no + || ! validate_replace_rtx (src, dest, insn)) + { + /* We have to restore reg_rtx_no to its old value, lest + recompute_reg_usage will try to compute the usage of the + new regs, yet reg_n_info is not valid for them. */ + reg_rtx_no = old_num_regs; + return; + } emit_insn_before (seq, insn); move_insn = PREV_INSN (insn); p_move_notes = ®_NOTES (move_insn);