mirror of https://github.com/mgba-emu/mgba.git
GBA Memory: Mark Famicom Mini games 22 through 28 as non-mirroring
This commit is contained in:
parent
5b7cfb463a
commit
93d3eaae1a
1
CHANGES
1
CHANGES
|
@ -1,6 +1,7 @@
|
|||
0.8.5: (Future)
|
||||
Emulation fixes:
|
||||
- ARM: Fix Addressing mode 1 shifter on rs == pc (fixes mgba.io/i/1926)
|
||||
- GBA Memory: Mark Famicom Mini games 22 through 28 as non-mirroring
|
||||
Other fixes:
|
||||
- CMake: Fix build with downstream minizip that exports incompatible symbols
|
||||
- Debugger: Close trace log when done tracing
|
||||
|
|
|
@ -190,6 +190,16 @@ static const struct GBACartridgeOverride _overrides[] = {
|
|||
// Aging cartridge
|
||||
{ "TCHK", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false },
|
||||
|
||||
// Famicom Mini series 3 (FDS), some aren't mirrored (22 - 28)
|
||||
// See https://forum.no-intro.org/viewtopic.php?f=2&t=4221 for discussion
|
||||
{ "FNMJ", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false },
|
||||
{ "FMRJ", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false },
|
||||
{ "FPTJ", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false },
|
||||
{ "FLBJ", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false },
|
||||
{ "FFMJ", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false },
|
||||
{ "FTKJ", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false },
|
||||
{ "FTUJ", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false },
|
||||
|
||||
{ { 0, 0, 0, 0 }, 0, 0, IDLE_LOOP_NONE, false }
|
||||
};
|
||||
|
||||
|
@ -200,20 +210,19 @@ bool GBAOverrideFind(const struct Configuration* config, struct GBACartridgeOver
|
|||
override->mirroring = false;
|
||||
bool found = false;
|
||||
|
||||
if (override->id[0] == 'F') {
|
||||
int i;
|
||||
for (i = 0; _overrides[i].id[0]; ++i) {
|
||||
if (memcmp(override->id, _overrides[i].id, sizeof(override->id)) == 0) {
|
||||
*override = _overrides[i];
|
||||
found = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (!found && override->id[0] == 'F') {
|
||||
// Classic NES Series
|
||||
override->savetype = SAVEDATA_EEPROM;
|
||||
override->mirroring = true;
|
||||
found = true;
|
||||
} else {
|
||||
int i;
|
||||
for (i = 0; _overrides[i].id[0]; ++i) {
|
||||
if (memcmp(override->id, _overrides[i].id, sizeof(override->id)) == 0) {
|
||||
*override = _overrides[i];
|
||||
found = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (config) {
|
||||
|
|
Loading…
Reference in New Issue