https://gcc.gnu.org/bugzilla/show_bug.cgi?id=118615

--- Comment #31 from Jakub Jelinek <jakub at gcc dot gnu.org> ---
Do you have a testcase where something behaves incorrectly?

For JUMP_P, I don't understand how the current behavior could be a problem, how
is a JUMP_P as current_insn (and therefore implying before_p for
split_if_necessary -> split_reg) fundamentally different between normal current
insn and some conditional jump in between the current insn and the use?  For
normal insn (i.e. !before_p) we'd insert before the next call which can be
after rather than before a JUMP_P in between.

For CALL_P we've already done first_call_insn = curr_insn; before
                      before_p = (JUMP_P (curr_insn)
                                  || (CALL_P (curr_insn) && reg->type ==
OP_IN));
                      if (NONDEBUG_INSN_P (curr_insn)
                          && (! JUMP_P (curr_insn) || reg->type == OP_IN)
                          && split_if_necessary (src_regno, reg->biggest_mode,
                                                 potential_reload_hard_regs,
                                                 before_p, curr_insn, max_uid))
and so in that case in split_reg first_call_insn == insn and so
BLOCK_FOR_INSN (first_call_insn) != BLOCK_FOR_INSN (insn)
will be false and so it behaves like older GCC versions.

Reply via email to