mirror of https://github.com/mgba-emu/mgba.git
GBA: Fix getting game info for multiboot ROMs
This commit is contained in:
parent
8ab2681bca
commit
b12858e974
1
CHANGES
1
CHANGES
|
@ -25,6 +25,7 @@ Other fixes:
|
||||||
- GB: Fix uninitialized save data when loading undersized temporary saves
|
- GB: Fix uninitialized save data when loading undersized temporary saves
|
||||||
- GB, GBA Core: Fix memory leak if reloading debug symbols
|
- GB, GBA Core: Fix memory leak if reloading debug symbols
|
||||||
- GB Serialize: Prevent loading invalid states where LY >= 144 in modes other than 1
|
- GB Serialize: Prevent loading invalid states where LY >= 144 in modes other than 1
|
||||||
|
- GBA: Fix getting game info for multiboot ROMs
|
||||||
- GBA Audio: Fix crash if audio FIFOs and timers get out of sync
|
- GBA Audio: Fix crash if audio FIFOs and timers get out of sync
|
||||||
- GBA Audio: Fix crash in audio subsampling if timing lockstep breaks
|
- GBA Audio: Fix crash in audio subsampling if timing lockstep breaks
|
||||||
- GBA Core: Fix loading symbols from ELF files if the file doesn't end with .elf
|
- GBA Core: Fix loading symbols from ELF files if the file doesn't end with .elf
|
||||||
|
|
|
@ -408,10 +408,14 @@ bool GBALoadMB(struct GBA* gba, struct VFile* vf) {
|
||||||
gba->mbVf = vf;
|
gba->mbVf = vf;
|
||||||
vf->seek(vf, 0, SEEK_SET);
|
vf->seek(vf, 0, SEEK_SET);
|
||||||
memset(gba->memory.wram, 0, GBA_SIZE_EWRAM);
|
memset(gba->memory.wram, 0, GBA_SIZE_EWRAM);
|
||||||
vf->read(vf, gba->memory.wram, GBA_SIZE_EWRAM);
|
off_t read = vf->read(vf, gba->memory.wram, GBA_SIZE_EWRAM);
|
||||||
|
if (read < 0) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
if (gba->cpu && gba->memory.activeRegion == GBA_REGION_IWRAM) {
|
if (gba->cpu && gba->memory.activeRegion == GBA_REGION_IWRAM) {
|
||||||
gba->cpu->memory.setActiveRegion(gba->cpu, gba->cpu->gprs[ARM_PC]);
|
gba->cpu->memory.setActiveRegion(gba->cpu, gba->cpu->gprs[ARM_PC]);
|
||||||
}
|
}
|
||||||
|
gba->romCrc32 = doCrc32(gba->memory.wram, read);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -856,7 +860,7 @@ void GBAGetGameInfo(const struct GBA* gba, struct mGameInfo* info) {
|
||||||
struct GBACartridge* cart = NULL;
|
struct GBACartridge* cart = NULL;
|
||||||
if (gba->memory.rom) {
|
if (gba->memory.rom) {
|
||||||
cart = (struct GBACartridge*) gba->memory.rom;
|
cart = (struct GBACartridge*) gba->memory.rom;
|
||||||
} else if (gba->isPristine && gba->memory.wram) {
|
} else if (gba->mbVf && gba->memory.wram) {
|
||||||
cart = (struct GBACartridge*) gba->memory.wram;
|
cart = (struct GBACartridge*) gba->memory.wram;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue