GBA Video: Fix VRAM access stalling even during force blanking

This commit is contained in:
Vicki Pfau 2024-06-24 01:16:12 -07:00
parent d8375a5896
commit e8bfaa210a
1 changed files with 9 additions and 5 deletions

View File

@ -32,7 +32,7 @@ static void GBAVideoDummyRendererPutPixels(struct GBAVideoRenderer* renderer, si
static void _startHblank(struct mTiming*, void* context, uint32_t cyclesLate); static void _startHblank(struct mTiming*, void* context, uint32_t cyclesLate);
static void _startHdraw(struct mTiming*, void* context, uint32_t cyclesLate); static void _startHdraw(struct mTiming*, void* context, uint32_t cyclesLate);
static unsigned _calculateStallMask(struct GBA* gba); static unsigned _calculateStallMask(struct GBA* gba, unsigned dispcnt);
MGBA_EXPORT const int GBAVideoObjSizes[16][2] = { MGBA_EXPORT const int GBAVideoObjSizes[16][2] = {
{ 8, 8 }, { 8, 8 },
@ -150,7 +150,8 @@ void _startHdraw(struct mTiming* timing, void* context, uint32_t cyclesLate) {
video->p->memory.io[GBA_REG(VCOUNT)] = video->vcount; video->p->memory.io[GBA_REG(VCOUNT)] = video->vcount;
if (video->vcount < GBA_VIDEO_VERTICAL_PIXELS) { if (video->vcount < GBA_VIDEO_VERTICAL_PIXELS) {
video->stallMask = _calculateStallMask(video->p); unsigned dispcnt = video->p->memory.io[GBA_REG(DISPCNT)];
video->stallMask = _calculateStallMask(video->p, dispcnt);
} }
GBARegisterDISPSTAT dispstat = video->p->memory.io[GBA_REG(DISPSTAT)]; GBARegisterDISPSTAT dispstat = video->p->memory.io[GBA_REG(DISPSTAT)];
@ -225,10 +226,13 @@ void GBAVideoWriteDISPSTAT(struct GBAVideo* video, uint16_t value) {
// TODO: Does a VCounter IRQ trigger on write? // TODO: Does a VCounter IRQ trigger on write?
} }
static unsigned _calculateStallMask(struct GBA* gba) { static unsigned _calculateStallMask(struct GBA* gba, unsigned dispcnt) {
unsigned mask = 0; unsigned mask = 0;
unsigned dispcnt = gba->memory.io[GBA_REG(DISPCNT)]; if (GBARegisterDISPCNTIsForcedBlank(dispcnt)) {
return 0;
}
switch (GBARegisterDISPCNTGetMode(dispcnt)) { switch (GBARegisterDISPCNTGetMode(dispcnt)) {
case 0: case 0:
if (GBARegisterDISPCNTIsBg0Enable(dispcnt)) { if (GBARegisterDISPCNTIsBg0Enable(dispcnt)) {
@ -446,7 +450,7 @@ void GBAVideoDeserialize(struct GBAVideo* video, const struct GBASerializedState
break; break;
case 2: case 2:
video->event.callback = _startHblank; video->event.callback = _startHblank;
video->stallMask = _calculateStallMask(video->p); video->stallMask = _calculateStallMask(video->p, state->io[GBA_REG(DISPCNT)]);
break; break;
case 3: case 3:
video->event.callback = _startHdraw; video->event.callback = _startHdraw;