mirror of
https://github.com/RetroDECK/Duckstation.git
synced 2024-11-22 13:55:38 +00:00
CPU/Recompiler: Fix jal/jalr to load delayed register
NewRec already handled this correctly.
This commit is contained in:
parent
87a7c09466
commit
aa658047f6
|
@ -2371,6 +2371,8 @@ bool CodeGenerator::Compile_Branch(Instruction instruction, const CodeCache::Ins
|
|||
|
||||
// now invalidate lr because it was possibly written in the branch
|
||||
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
|
||||
|
|
|
@ -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)
|
||||
{
|
||||
// There shouldn't be a flush at the same time as there's a new load delay.
|
||||
|
|
|
@ -390,6 +390,9 @@ public:
|
|||
/// Moves load delay to the next load delay, and writes any previous load delay to the destination register.
|
||||
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.
|
||||
void WriteLoadDelayToCPU(bool clear);
|
||||
|
||||
|
|
Loading…
Reference in a new issue