mirror of https://github.com/PCSX2/pcsx2.git
x86/microVU: Fix VU1->VU0 register access in MTVU mode
eax wasn't being backed up, and in most cases it contains the address we're loading from/storing to.
This commit is contained in:
parent
79764430d8
commit
4ea331ecf2
|
@ -135,8 +135,9 @@ void mvuGenerateWaitMTVU(mV)
|
|||
if (!xRegister32::IsCallerSaved(i) || i == rsp.GetId())
|
||||
continue;
|
||||
|
||||
// no need to save temps
|
||||
if (i == gprT1.GetId() || i == gprT2.GetId())
|
||||
// T1 often contains the address we're loading when waiting for VU1.
|
||||
// T2 isn't used until afterwards, so don't bother saving it.
|
||||
if (i == gprT2.GetId())
|
||||
continue;
|
||||
|
||||
xPUSH(xRegister64(i));
|
||||
|
@ -187,7 +188,7 @@ void mvuGenerateWaitMTVU(mV)
|
|||
if (!xRegister32::IsCallerSaved(i) || i == rsp.GetId())
|
||||
continue;
|
||||
|
||||
if (i == gprT1.GetId() || i == gprT2.GetId())
|
||||
if (i == gprT2.GetId())
|
||||
continue;
|
||||
|
||||
xPOP(xRegister64(i));
|
||||
|
|
|
@ -326,7 +326,9 @@ __fi void mVUaddrFix(mV, const xAddressReg& gprReg)
|
|||
{
|
||||
xMOV(gprT1, mVU.prog.cur->idx); // Note: Kernel does it via COP2 to initialize VU1!
|
||||
xMOV(gprT2, xPC); // So we don't spam console, we'll only check micro-mode...
|
||||
mVUbackupRegs(mVU, true, false);
|
||||
xFastCall((void*)mVUwarningRegAccess, arg1regd, arg2regd);
|
||||
mVUrestoreRegs(mVU, true, false);
|
||||
}
|
||||
#endif
|
||||
xFastCall((void*)mVU.waitMTVU);
|
||||
|
|
Loading…
Reference in New Issue