mirror of https://github.com/PCSX2/pcsx2.git
parent
1483e4f88e
commit
7166c04ff2
|
@ -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();
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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
|
||||||
{
|
{
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue