mirror of https://github.com/mgba-emu/mgba.git
GBA Memory: Let raw access read high MMIO addresses
This commit is contained in:
parent
f298c0185e
commit
f84208a3e4
1
CHANGES
1
CHANGES
|
@ -20,6 +20,7 @@ Other fixes:
|
||||||
- Core: Fix inconsistencies with setting game-specific overrides (fixes mgba.io/i/2963)
|
- Core: Fix inconsistencies with setting game-specific overrides (fixes mgba.io/i/2963)
|
||||||
- Debugger: Fix writing to specific segment in command-line debugger
|
- Debugger: Fix writing to specific segment in command-line debugger
|
||||||
- GB: Fix uninitialized save data when loading undersized temporary saves
|
- GB: Fix uninitialized save data when loading undersized temporary saves
|
||||||
|
- GBA Memory: Let raw access read high MMIO addresses
|
||||||
- Qt: Fix savestate preview sizes with different scales (fixes mgba.io/i/2560)
|
- Qt: Fix savestate preview sizes with different scales (fixes mgba.io/i/2560)
|
||||||
- Updater: Fix updating appimage across filesystems
|
- Updater: Fix updating appimage across filesystems
|
||||||
Misc:
|
Misc:
|
||||||
|
|
|
@ -1118,10 +1118,8 @@ uint32_t GBAView32(struct ARMCore* cpu, uint32_t address) {
|
||||||
value = GBALoad32(cpu, address, 0);
|
value = GBALoad32(cpu, address, 0);
|
||||||
break;
|
break;
|
||||||
case GBA_REGION_IO:
|
case GBA_REGION_IO:
|
||||||
if ((address & OFFSET_MASK) < GBA_REG_MAX) {
|
value = GBAView16(cpu, address);
|
||||||
value = gba->memory.io[(address & OFFSET_MASK) >> 1];
|
value |= GBAView16(cpu, address + 2) << 16;
|
||||||
value |= gba->memory.io[((address & OFFSET_MASK) >> 1) + 1] << 16;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case GBA_REGION_SRAM:
|
case GBA_REGION_SRAM:
|
||||||
value = GBALoad8(cpu, address, 0);
|
value = GBALoad8(cpu, address, 0);
|
||||||
|
@ -1159,7 +1157,10 @@ uint16_t GBAView16(struct ARMCore* cpu, uint32_t address) {
|
||||||
value = GBALoad16(cpu, address, 0);
|
value = GBALoad16(cpu, address, 0);
|
||||||
break;
|
break;
|
||||||
case GBA_REGION_IO:
|
case GBA_REGION_IO:
|
||||||
if ((address & OFFSET_MASK) < GBA_REG_MAX) {
|
if ((address & OFFSET_MASK) < GBA_REG_MAX || (address & OFFSET_MASK) == GBA_REG_POSTFLG) {
|
||||||
|
value = gba->memory.io[(address & OFFSET_MASK) >> 1];
|
||||||
|
} else if ((address & OFFSET_MASK) == GBA_REG_EXWAITCNT_LO || (address & OFFSET_MASK) == GBA_REG_EXWAITCNT_HI) {
|
||||||
|
address += GBA_REG_INTERNAL_EXWAITCNT_LO - GBA_REG_EXWAITCNT_LO;
|
||||||
value = gba->memory.io[(address & OFFSET_MASK) >> 1];
|
value = gba->memory.io[(address & OFFSET_MASK) >> 1];
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in New Issue