R3000: Serialize IOP->EE ticks carry

[SAVEVERSION+]
This commit is contained in:
Stenzek 2024-05-16 19:12:44 +10:00 committed by Connor McLaughlin
parent 1483e4f88e
commit 7166c04ff2
5 changed files with 7 additions and 8 deletions

View File

@ -44,6 +44,7 @@ void psxReset()
psxRegs.iopBreak = 0; psxRegs.iopBreak = 0;
psxRegs.iopCycleEE = -1; psxRegs.iopCycleEE = -1;
psxRegs.iopCycleEECarry = 0;
psxRegs.iopNextEventCycle = psxRegs.cycle + 4; psxRegs.iopNextEventCycle = psxRegs.cycle + 4;
psxHwReset(); psxHwReset();

View File

@ -110,6 +110,7 @@ struct psxRegisters {
// Tracks current number of cycles IOP can run in EE cycles. When it dips below zero, // Tracks current number of cycles IOP can run in EE cycles. When it dips below zero,
// control is returned to the EE. // control is returned to the EE.
s32 iopCycleEE; s32 iopCycleEE;
u32 iopCycleEECarry;
u32 sCycle[32]; // start cycle for signaled ints u32 sCycle[32]; // start cycle for signaled ints
s32 eCycle[32]; // cycle delta for signaled ints (sCycle + eCycle == branch cycle) s32 eCycle[32]; // cycle delta for signaled ints (sCycle + eCycle == branch cycle)

View File

@ -279,10 +279,9 @@ static s32 intExecuteBlock( s32 eeCycles )
const u32 cdenom = 147; // PSXCLK / F const u32 cdenom = 147; // PSXCLK / F
//One of the Iop to EE delta clocks to be set in PS1 mode. //One of the Iop to EE delta clocks to be set in PS1 mode.
static u32 carry; const u32 t = ((cnum * (psxRegs.cycle - lastIOPCycle)) + psxRegs.iopCycleEECarry);
const u32 t = ((cnum * (psxRegs.cycle - lastIOPCycle)) + carry);
psxRegs.iopCycleEE -= t / cdenom; psxRegs.iopCycleEE -= t / cdenom;
carry = t % cdenom; psxRegs.iopCycleEECarry = t % cdenom;
} }
else else
{ {

View File

@ -25,7 +25,7 @@ enum class FreezeAction
// [SAVEVERSION+] // [SAVEVERSION+]
// This informs the auto updater that the users savestates will be invalidated. // This informs the auto updater that the users savestates will be invalidated.
static const u32 g_SaveVersion = (0x9A4E << 16) | 0x0000; static const u32 g_SaveVersion = (0x9A4F << 16) | 0x0000;
// the freezing data between submodules and core // the freezing data between submodules and core

View File

@ -1141,15 +1141,13 @@ static void iPsxAddEECycles(u32 blockCycles)
const u32 cnum = 1280; // PS2CLK / F const u32 cnum = 1280; // PS2CLK / F
const u32 cdenom = 147; // PSXCLK / F const u32 cdenom = 147; // PSXCLK / F
static u32 ticks_carry = 0;
if (blockCycles != 0xFFFFFFFF) if (blockCycles != 0xFFFFFFFF)
xMOV(eax, blockCycles * cnum); xMOV(eax, blockCycles * cnum);
xADD(eax, ptr32[&ticks_carry]); xADD(eax, ptr32[&psxRegs.iopCycleEECarry]);
xMOV(ecx, cdenom); xMOV(ecx, cdenom);
xXOR(edx, edx); xXOR(edx, edx);
xUDIV(ecx); xUDIV(ecx);
xMOV(ptr32[&ticks_carry], edx); xMOV(ptr32[&psxRegs.iopCycleEECarry], edx);
xSUB(ptr32[&psxRegs.iopCycleEE], eax); xSUB(ptr32[&psxRegs.iopCycleEE], eax);
} }