From 12784a71e2be8bd65613d0dd506f637220050784 Mon Sep 17 00:00:00 2001 From: Thomas Harte Date: Tue, 29 Dec 2020 20:53:56 -0500 Subject: [PATCH] A stab in the dark: does the IOLC inhibit also affect vector fetches? --- Machines/Apple/AppleIIgs/AppleIIgs.cpp | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/Machines/Apple/AppleIIgs/AppleIIgs.cpp b/Machines/Apple/AppleIIgs/AppleIIgs.cpp index 6e24ce486..92f72ef59 100644 --- a/Machines/Apple/AppleIIgs/AppleIIgs.cpp +++ b/Machines/Apple/AppleIIgs/AppleIIgs.cpp @@ -237,9 +237,10 @@ class ConcreteMachine: static uint64_t total = 0; bool is_1Mhz = false; - if(operation == CPU::WDC65816::BusOperation::ReadVector) { + if(operation == CPU::WDC65816::BusOperation::ReadVector && !(memory_.get_shadow_register()&0x40)) { // I think vector pulls always go to ROM? // That's slightly implied in the documentation, and doing so makes GS/OS boot, so... + // TODO: but is my guess above re: not doing that if IOLC shadowing is disabled correct? *value = rom_[rom_.size() - 65536 + address]; } else if(region.flags & MemoryMap::Region::IsIO) { // Ensure classic auxiliary and language card accesses have effect. @@ -789,7 +790,8 @@ class ConcreteMachine: // operation == CPU::WDC65816::BusOperation::ReadOpcode ? " [*]" : ""); // } if(operation == CPU::WDC65816::BusOperation::ReadOpcode) { - log = (address >= 0xff6cdc) && (address < 0xff6d43); +// log = (address >= 0xff6cdc) && (address < 0xff6d43); + log = (address >= 0x00d300) && (address < 0x00d600); } // log &= !((operation == CPU::WDC65816::BusOperation::ReadOpcode) && ((address < 0xff6a2c) || (address >= 0xff6a9c))); if(log) {