reactivated direct peeks for PlusROMs

This commit is contained in:
Thomas Jentzsch 2021-10-16 22:55:08 +02:00
parent 299024bb58
commit c7205f1665
1 changed files with 7 additions and 4 deletions

View File

@ -59,9 +59,7 @@ CartridgeEnhanced::CartridgeEnhanced(const ByteBuffer& image, size_t size,
myPlusROM = make_unique<PlusROM>(mySettings, *this); myPlusROM = make_unique<PlusROM>(mySettings, *this);
// Determine whether we have a PlusROM cart // Determine whether we have a PlusROM cart
// PlusROM needs to call peek() method, so disable direct peeks myPlusROM->initialize(myImage, mySize);
if(myPlusROM->initialize(myImage, mySize))
myDirectPeek = false;
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
@ -246,6 +244,7 @@ bool CartridgeEnhanced::bank(uInt16 bank, uInt16 segment)
const uInt32 bankOffset = myCurrentSegOffset[segment] = romBank << myBankShift; const uInt32 bankOffset = myCurrentSegOffset[segment] = romBank << myBankShift;
const uInt16 hotspot = this->hotspot(); const uInt16 hotspot = this->hotspot();
uInt16 hotSpotAddr; uInt16 hotSpotAddr;
uInt16 plusROMAddr;
// Skip extra RAM; if existing it is only mapped into first segment // Skip extra RAM; if existing it is only mapped into first segment
const uInt16 fromAddr = (ROM_OFFSET + segmentOffset + (segment == 0 ? myRomOffset : 0)) & ~System::PAGE_MASK; const uInt16 fromAddr = (ROM_OFFSET + segmentOffset + (segment == 0 ? myRomOffset : 0)) & ~System::PAGE_MASK;
// for ROMs < 4_KB, the whole address space will be mapped. // for ROMs < 4_KB, the whole address space will be mapped.
@ -255,6 +254,10 @@ bool CartridgeEnhanced::bank(uInt16 bank, uInt16 segment)
hotSpotAddr = (hotspot & ~System::PAGE_MASK); hotSpotAddr = (hotspot & ~System::PAGE_MASK);
else else
hotSpotAddr = 0xFFFF; // none hotSpotAddr = 0xFFFF; // none
if(myPlusROM->isValid())
plusROMAddr = (0x1FF0 & ~System::PAGE_MASK);
else
plusROMAddr = 0xFFFF; // none
System::PageAccess access(this, System::PageAccessType::READ); System::PageAccess access(this, System::PageAccessType::READ);
// Setup the page access methods for the current bank // Setup the page access methods for the current bank
@ -262,7 +265,7 @@ bool CartridgeEnhanced::bank(uInt16 bank, uInt16 segment)
{ {
const uInt32 offset = bankOffset + (addr & myBankMask); const uInt32 offset = bankOffset + (addr & myBankMask);
if(myDirectPeek && addr != hotSpotAddr) if(myDirectPeek && addr != hotSpotAddr && addr != plusROMAddr)
access.directPeekBase = &myImage[offset]; access.directPeekBase = &myImage[offset];
else else
access.directPeekBase = nullptr; access.directPeekBase = nullptr;