GB MBC: Fix MBC2 bit selection

This commit is contained in:
Vicki Pfau 2020-06-16 20:49:07 -07:00
parent c487b0cf43
commit 1402593855
6 changed files with 13 additions and 6 deletions

View File

@ -7,6 +7,7 @@ Emulation fixes:
- ARM: Fix STR storing PC after address calculation - ARM: Fix STR storing PC after address calculation
- GB MBC: Fix MBC1 mode changing behavior - GB MBC: Fix MBC1 mode changing behavior
- GB MBC: Fix MBC1 RAM enable bit selection - GB MBC: Fix MBC1 RAM enable bit selection
- GB MBC: Fix MBC2 bit selection
- GB Video: Fix state after skipping BIOS (fixes mgba.io/i/1715 and mgba.io/i/1716) - GB Video: Fix state after skipping BIOS (fixes mgba.io/i/1715 and mgba.io/i/1716)
- GBA: Fix timing advancing too quickly in rare cases - GBA: Fix timing advancing too quickly in rare cases
- GBA BIOS: Implement dummy sound driver calls - GBA BIOS: Implement dummy sound driver calls

Binary file not shown.

After

Width:  |  Height:  |  Size: 528 B

View File

@ -1,2 +1,2 @@
[testinfo] [testinfo]
fail=1 skip=360

Binary file not shown.

After

Width:  |  Height:  |  Size: 528 B

View File

@ -1,2 +1,2 @@
[testinfo] [testinfo]
fail=1 skip=360

View File

@ -480,9 +480,9 @@ void _GBMBC2(struct GB* gb, uint16_t address, uint8_t value) {
struct GBMemory* memory = &gb->memory; struct GBMemory* memory = &gb->memory;
int shift = (address & 1) * 4; int shift = (address & 1) * 4;
int bank = value & 0xF; int bank = value & 0xF;
switch (address >> 13) { switch ((address & 0xC100) >> 8) {
case 0x0: case 0x0:
switch (value) { switch (value & 0x0F) {
case 0: case 0:
memory->sramAccess = false; memory->sramAccess = false;
break; break;
@ -491,7 +491,7 @@ void _GBMBC2(struct GB* gb, uint16_t address, uint8_t value) {
break; break;
default: default:
// TODO // TODO
mLOG(GB_MBC, STUB, "MBC1 unknown value %02X", value); mLOG(GB_MBC, STUB, "MBC2 unknown value %02X", value);
break; break;
} }
break; break;
@ -501,7 +501,10 @@ void _GBMBC2(struct GB* gb, uint16_t address, uint8_t value) {
} }
GBMBCSwitchBank(gb, bank); GBMBCSwitchBank(gb, bank);
break; break;
case 0x5: case 0x80:
case 0x81:
case 0x82:
case 0x83:
if (!memory->sramAccess) { if (!memory->sramAccess) {
return; return;
} }
@ -517,6 +520,9 @@ void _GBMBC2(struct GB* gb, uint16_t address, uint8_t value) {
} }
static uint8_t _GBMBC2Read(struct GBMemory* memory, uint16_t address) { static uint8_t _GBMBC2Read(struct GBMemory* memory, uint16_t address) {
if (!memory->sramAccess) {
return 0xFF;
}
address &= 0x1FF; address &= 0x1FF;
int shift = (address & 1) * 4; int shift = (address & 1) * 4;
return (memory->sramBank[(address >> 1)] >> shift) | 0xF0; return (memory->sramBank[(address >> 1)] >> shift) | 0xF0;