CPU/Recompiler: Fix jal/jalr to load delayed register

NewRec already handled this correctly.
This commit is contained in:
Stenzek 2023-12-15 21:46:23 +10:00
parent 87a7c09466
commit aa658047f6
No known key found for this signature in database
3 changed files with 15 additions and 0 deletions

View File

@ -2371,6 +2371,8 @@ bool CodeGenerator::Compile_Branch(Instruction instruction, const CodeCache::Ins
// now invalidate lr because it was possibly written in the branch // now invalidate lr because it was possibly written in the branch
m_register_cache.InvalidateGuestRegister(lr_reg); m_register_cache.InvalidateGuestRegister(lr_reg);
if (m_register_cache.GetLoadDelayRegister() == lr_reg)
m_register_cache.CancelLoadDelay();
} }
// we don't need to test the address of constant branches unless they're definitely misaligned, which would be // we don't need to test the address of constant branches unless they're definitely misaligned, which would be

View File

@ -753,6 +753,16 @@ void RegisterCache::UpdateLoadDelay()
} }
} }
void RegisterCache::CancelLoadDelay()
{
if (m_state.load_delay_register == Reg::count)
return;
Log_DebugPrintf("Cancelling load delay of register %s", GetRegName(m_state.load_delay_register));
m_state.load_delay_register = Reg::count;
m_state.load_delay_value.ReleaseAndClear();
}
void RegisterCache::WriteLoadDelayToCPU(bool clear) void RegisterCache::WriteLoadDelayToCPU(bool clear)
{ {
// There shouldn't be a flush at the same time as there's a new load delay. // There shouldn't be a flush at the same time as there's a new load delay.

View File

@ -390,6 +390,9 @@ public:
/// Moves load delay to the next load delay, and writes any previous load delay to the destination register. /// Moves load delay to the next load delay, and writes any previous load delay to the destination register.
void UpdateLoadDelay(); void UpdateLoadDelay();
/// Cancels any present load delay.
void CancelLoadDelay();
/// Writes the load delay to the CPU structure, so it is synced up with the interpreter. /// Writes the load delay to the CPU structure, so it is synced up with the interpreter.
void WriteLoadDelayToCPU(bool clear); void WriteLoadDelayToCPU(bool clear);