From: J"orn Rennecke Date: Thu, 2 Nov 2000 19:22:04 +0000 (+0000) Subject: reload.c (find_equiv_reg): Test all hard registers for membership in the requested... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=0192d704659dcc776b2365fa03415ce24f5c0af1;p=gcc.git reload.c (find_equiv_reg): Test all hard registers for membership in the requested class. * reload.c (find_equiv_reg): Test all hard registers for membership in the requested class. From-SVN: r37207 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index c6b37dfd079..17674bedf4c 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +Thu Nov 2 19:20:12 2000 J"orn Rennecke + + * reload.c (find_equiv_reg): Test all hard registers for membership + in the requested class. + 2000-11-02 Joseph S. Myers * collect2.c (main, write_c_file_stat), gcc.c (translate_options, diff --git a/gcc/reload.c b/gcc/reload.c index f3933b116f6..57ff486f849 100644 --- a/gcc/reload.c +++ b/gcc/reload.c @@ -6185,16 +6185,29 @@ find_equiv_reg (goal, insn, class, other, reload_reg_p, goalreg, mode) && (valtry = operand_subword (SET_DEST (pat), 1, 0, VOIDmode)) && (valueno = true_regnum (valtry)) >= 0))) - if (other >= 0 - ? valueno == other - : ((unsigned) valueno < FIRST_PSEUDO_REGISTER - && TEST_HARD_REG_BIT (reg_class_contents[(int) class], - valueno))) - { - value = valtry; - where = p; - break; - } + { + if (other >= 0) + { + if (valueno != other) + continue; + } + else if ((unsigned) valueno >= FIRST_PSEUDO_REGISTER) + continue; + else + { + int i; + + for (i = HARD_REGNO_NREGS (valueno, mode) - 1; i >= 0; i--) + if (! TEST_HARD_REG_BIT (reg_class_contents[(int) class], + valueno + i)) + break; + if (i >= 0) + continue; + } + value = valtry; + where = p; + break; + } } }