summaryrefslogtreecommitdiff
path: root/genesis.c
diff options
context:
space:
mode:
authorMike Pavone <pavone@retrodev.com>2020-06-01 23:59:59 -0700
committerMike Pavone <pavone@retrodev.com>2020-06-01 23:59:59 -0700
commit746521c2c47a465109342d8d4508073ee5e5db93 (patch)
treeef0ea6d24ceaf4a5f4f502963b01b406cdd9e59e /genesis.c
parent6956da15b02af149709945a12fc3a56a031ed1ad (diff)
Fix handling of unmapped reads/writes to the cart/expansion port region
Diffstat (limited to 'genesis.c')
-rw-r--r--genesis.c10
1 files changed, 7 insertions, 3 deletions
diff --git a/genesis.c b/genesis.c
index 3c2dc17..7733f91 100644
--- a/genesis.c
+++ b/genesis.c
@@ -1089,7 +1089,7 @@ static uint16_t unused_read(uint32_t location, void *vcontext)
{
m68k_context *context = vcontext;
genesis_context *gen = context->system;
- if ((location >= 0xA13000 && location < 0xA13100) || (location >= 0xA12000 && location < 0xA12100)) {
+ if (location < 0x800000 || (location >= 0xA13000 && location < 0xA13100) || (location >= 0xA12000 && location < 0xA12100)) {
//Only called if the cart/exp doesn't have a more specific handler for this region
return get_open_bus_value(&gen->header);
} else if (location == 0xA14000 || location == 0xA14002) {
@@ -1131,7 +1131,9 @@ static void *unused_write(uint32_t location, void *vcontext, uint16_t value)
gen->tmss_lock[location >> 1 & 1] = value;
} else if (has_tmss && location == 0xA14100) {
//TODO: implement TMSS control register
- } else if (location < 0xA12000 || location >= 0xA13100 || (location >= 0xA12100 && location < 0xA13000)) {
+ } else if (location < 0x800000 || (location >= 0xA13000 && location < 0xA13100) || (location >= 0xA12000 && location < 0xA12100)) {
+ //these writes are ignored when no relevant hardware is present
+ } else {
fatal_error("Machine freeze due to unmapped write to %X\n", location);
}
return vcontext;
@@ -1153,7 +1155,9 @@ static void *unused_write_b(uint32_t location, void *vcontext, uint8_t value)
}
} else if (has_tmss && (location == 0xA14100 || location == 0xA14101)) {
//TODO: implement TMSS control register
- } else if (location < 0xA12000 || location >= 0xA13100 || (location >= 0xA12100 && location < 0xA13000)) {
+ } else if (location < 0x800000 || (location >= 0xA13000 && location < 0xA13100) || (location >= 0xA12000 && location < 0xA12100)) {
+ //these writes are ignored when no relevant hardware is present
+ } else {
fatal_error("Machine freeze due to unmapped byte write to %X\n", location);
}
return vcontext;