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
|
// 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
|
||||||
|
|
|
@ -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.
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue