mirror of https://github.com/mgba-emu/mgba.git
GBA Memory: Improve gamepak prefetch timing
This commit is contained in:
parent
0e49b2d391
commit
8a6cf8dc9c
1
CHANGES
1
CHANGES
|
@ -92,6 +92,7 @@ Emulation fixes:
|
||||||
- ARM: Fix stepping when events are pending
|
- ARM: Fix stepping when events are pending
|
||||||
- GBA DMA: Fix case where DMAs could get misaligned (fixes mgba.io/i/1092)
|
- GBA DMA: Fix case where DMAs could get misaligned (fixes mgba.io/i/1092)
|
||||||
- GBA Memory: Fix open bus from IWRAM (fixes mgba.io/i/1575)
|
- GBA Memory: Fix open bus from IWRAM (fixes mgba.io/i/1575)
|
||||||
|
- GBA Memory: Improve gamepak prefetch timing
|
||||||
- GBA Timers: Improve timer startup emulation
|
- GBA Timers: Improve timer startup emulation
|
||||||
- GBA Video: Fix OpenGL renderer 512x512 backgrounds (fixes mgba.io/i/1572)
|
- GBA Video: Fix OpenGL renderer 512x512 backgrounds (fixes mgba.io/i/1572)
|
||||||
- GBA Video: Fix BLDY for semitransparent sprite on non-target-2 backgrounds
|
- GBA Video: Fix BLDY for semitransparent sprite on non-target-2 backgrounds
|
||||||
|
|
|
@ -1622,17 +1622,19 @@ int32_t GBAMemoryStall(struct ARMCore* cpu, int32_t wait) {
|
||||||
maxLoads -= previousLoads;
|
maxLoads -= previousLoads;
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t s = cpu->memory.activeSeqCycles16 + 1;
|
int32_t s = cpu->memory.activeSeqCycles16;
|
||||||
int32_t n2s = cpu->memory.activeNonseqCycles16 - cpu->memory.activeSeqCycles16 + 1;
|
int32_t n2s = cpu->memory.activeNonseqCycles16 - cpu->memory.activeSeqCycles16 + 1;
|
||||||
|
|
||||||
// Figure out how many sequential loads we can jam in
|
// Figure out how many sequential loads we can jam in
|
||||||
int32_t stall = s;
|
int32_t stall = s + 1;
|
||||||
int32_t loads = 1;
|
int32_t loads = 1;
|
||||||
|
|
||||||
while (stall < wait && loads < maxLoads) {
|
while (stall < wait && loads < maxLoads) {
|
||||||
stall += s;
|
stall += s;
|
||||||
++loads;
|
++loads;
|
||||||
}
|
}
|
||||||
|
memory->lastPrefetchedPc = cpu->gprs[ARM_PC] + WORD_SIZE_THUMB * (loads + previousLoads - 1);
|
||||||
|
|
||||||
if (stall > wait) {
|
if (stall > wait) {
|
||||||
// The wait cannot take less time than the prefetch stalls
|
// The wait cannot take less time than the prefetch stalls
|
||||||
wait = stall;
|
wait = stall;
|
||||||
|
@ -1641,10 +1643,9 @@ int32_t GBAMemoryStall(struct ARMCore* cpu, int32_t wait) {
|
||||||
// This instruction used to have an N, convert it to an S.
|
// This instruction used to have an N, convert it to an S.
|
||||||
wait -= n2s;
|
wait -= n2s;
|
||||||
|
|
||||||
memory->lastPrefetchedPc = cpu->gprs[ARM_PC] + WORD_SIZE_THUMB * (loads + previousLoads - 1);
|
|
||||||
|
|
||||||
// The next |loads|S waitstates disappear entirely, so long as they're all in a row
|
// The next |loads|S waitstates disappear entirely, so long as they're all in a row
|
||||||
cpu->cycles -= (s - 1) * loads;
|
wait -= stall - 1;
|
||||||
|
|
||||||
return wait;
|
return wait;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue