return res;
}
-/* Return true if REGNO is used for return in the current
- function. */
-static bool
-return_regno_p (unsigned int regno)
-{
- rtx outgoing = crtl->return_rtx;
-
- if (! outgoing)
- return false;
-
- if (REG_P (outgoing))
- return REGNO (outgoing) == regno;
- else if (GET_CODE (outgoing) == PARALLEL)
- {
- int i;
-
- for (i = 0; i < XVECLEN (outgoing, 0); i++)
- {
- rtx x = XEXP (XVECEXP (outgoing, 0, i), 0);
-
- if (REG_P (x) && REGNO (x) == regno)
- return true;
- }
- }
- return false;
-}
-
-/* Return true if REGNO is in one of subsequent USE after INSN in the
- same BB. */
-static bool
-regno_in_use_p (rtx_insn *insn, unsigned int regno)
-{
- static lra_insn_recog_data_t id;
- static struct lra_static_insn_data *static_id;
- struct lra_insn_reg *reg;
- int i, arg_regno;
- basic_block bb = BLOCK_FOR_INSN (insn);
-
- while ((insn = next_nondebug_insn (insn)) != NULL_RTX)
- {
- if (BARRIER_P (insn) || bb != BLOCK_FOR_INSN (insn))
- return false;
- if (! INSN_P (insn))
- continue;
- if (GET_CODE (PATTERN (insn)) == USE
- && REG_P (XEXP (PATTERN (insn), 0))
- && regno == REGNO (XEXP (PATTERN (insn), 0)))
- return true;
- /* Check that the regno is not modified. */
- id = lra_get_insn_recog_data (insn);
- for (reg = id->regs; reg != NULL; reg = reg->next)
- if (reg->type != OP_IN && reg->regno == (int) regno)
- return false;
- static_id = id->insn_static_data;
- for (reg = static_id->hard_regs; reg != NULL; reg = reg->next)
- if (reg->type != OP_IN && reg->regno == (int) regno)
- return false;
- if (id->arg_hard_regs != NULL)
- for (i = 0; (arg_regno = id->arg_hard_regs[i]) >= 0; i++)
- if ((int) regno == (arg_regno >= FIRST_PSEUDO_REGISTER
- ? arg_regno : arg_regno - FIRST_PSEUDO_REGISTER))
- return false;
- }
- return false;
-}
-
/* Final change of pseudos got hard registers into the corresponding
hard registers and removing temporary clobbers. */
void
if (NONJUMP_INSN_P (insn) && GET_CODE (pat) == SET
&& REG_P (SET_SRC (pat)) && REG_P (SET_DEST (pat))
&& REGNO (SET_SRC (pat)) == REGNO (SET_DEST (pat))
- && (! return_regno_p (REGNO (SET_SRC (pat)))
- || ! regno_in_use_p (insn, REGNO (SET_SRC (pat)))))
+ && REGNO (SET_SRC (pat)) >= FIRST_PSEUDO_REGISTER)
{
lra_invalidate_insn_data (insn);
delete_insn (insn);