GB MBC: Force minimum SRAM size on rare MBCs that always have SRAM

This commit is contained in:
Vicki Pfau 2021-03-24 18:59:56 -07:00
parent 1b81c08de8
commit 32b7cc2fba
2 changed files with 7 additions and 0 deletions

View File

@ -85,6 +85,7 @@ Other fixes:
- FFmpeg: Fix encoding of time base - FFmpeg: Fix encoding of time base
- GB: Fix crash when changing ROM while in banked address space - GB: Fix crash when changing ROM while in banked address space
- GB: Fix loading model overrides - GB: Fix loading model overrides
- GB MBC: Force minimum SRAM size on rare MBCs that always have SRAM
- GB Serialize: Fix crash when loading pre-0.7 SGB savestates - GB Serialize: Fix crash when loading pre-0.7 SGB savestates
- GB Video: Fix SGB video logs - GB Video: Fix SGB video logs
- GB Video: Discard SGB packets in non-SGB mVLs - GB Video: Discard SGB packets in non-SGB mVLs

View File

@ -353,6 +353,9 @@ void GBMBCInit(struct GB* gb) {
gb->memory.mbcWrite = _GBMBC6; gb->memory.mbcWrite = _GBMBC6;
gb->memory.mbcRead = _GBMBC6Read; gb->memory.mbcRead = _GBMBC6Read;
gb->memory.directSramAccess = false; gb->memory.directSramAccess = false;
if (!gb->sramSize) {
gb->sramSize = GB_SIZE_EXTERNAL_RAM; // Force minimum size for convenience
}
gb->sramSize += GB_SIZE_MBC6_FLASH; // Flash is concatenated at the end gb->sramSize += GB_SIZE_MBC6_FLASH; // Flash is concatenated at the end
break; break;
case GB_MBC7: case GB_MBC7:
@ -386,6 +389,9 @@ void GBMBCInit(struct GB* gb) {
case GB_POCKETCAM: case GB_POCKETCAM:
gb->memory.mbcWrite = _GBPocketCam; gb->memory.mbcWrite = _GBPocketCam;
gb->memory.mbcRead = _GBPocketCamRead; gb->memory.mbcRead = _GBPocketCamRead;
if (!gb->sramSize) {
gb->sramSize = GB_SIZE_EXTERNAL_RAM; // Force minimum size for convenience
}
if (gb->memory.cam && gb->memory.cam->startRequestImage) { if (gb->memory.cam && gb->memory.cam->startRequestImage) {
gb->memory.cam->startRequestImage(gb->memory.cam, GBCAM_WIDTH, GBCAM_HEIGHT, mCOLOR_ANY); gb->memory.cam->startRequestImage(gb->memory.cam, GBCAM_WIDTH, GBCAM_HEIGHT, mCOLOR_ANY);
} }