mirror of https://github.com/stella-emu/stella.git
Updated RWP stuff for DASH scheme.
Again, this is a relatively untested BS scheme, with only one test ROM available.
This commit is contained in:
parent
70fcd0f3b5
commit
a26288c788
|
@ -116,7 +116,6 @@ bool Cartridge3EPlus::poke(uInt16 address, uInt8 value)
|
||||||
|
|
||||||
if(address == BANK_SWITCH_HOTSPOT_RAM)
|
if(address == BANK_SWITCH_HOTSPOT_RAM)
|
||||||
changed = bankRAM(value);
|
changed = bankRAM(value);
|
||||||
|
|
||||||
else if(address == BANK_SWITCH_HOTSPOT_ROM)
|
else if(address == BANK_SWITCH_HOTSPOT_ROM)
|
||||||
changed = bankROM(value);
|
changed = bankROM(value);
|
||||||
|
|
||||||
|
|
|
@ -99,21 +99,12 @@ uInt8 CartridgeDASH::peek(uInt16 address)
|
||||||
|
|
||||||
}
|
}
|
||||||
else if(imageBank & BITMASK_ROMRAM) // a RAM bank
|
else if(imageBank & BITMASK_ROMRAM) // a RAM bank
|
||||||
{
|
|
||||||
// Reading from the write port triggers an unwanted write
|
|
||||||
value = mySystem->getDataBusState(0xFF);
|
|
||||||
|
|
||||||
if(bankLocked())
|
|
||||||
return value;
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
Int32 ramBank = imageBank & BIT_BANK_MASK; // discard irrelevant bits
|
Int32 ramBank = imageBank & BIT_BANK_MASK; // discard irrelevant bits
|
||||||
Int32 offset = ramBank << RAM_BANK_TO_POWER; // base bank address in RAM
|
Int32 offset = ramBank << RAM_BANK_TO_POWER; // base bank address in RAM
|
||||||
offset += (address & BITMASK_RAM_BANK); // + byte offset in RAM bank
|
offset += (address & BITMASK_RAM_BANK); // + byte offset in RAM bank
|
||||||
myRAM[offset] = value;
|
|
||||||
triggerReadFromWritePort(peekAddress);
|
return peekRAM(myRAM[offset], peekAddress);
|
||||||
return value;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return value;
|
return value;
|
||||||
|
@ -129,12 +120,27 @@ bool CartridgeDASH::poke(uInt16 address, uInt8 value)
|
||||||
|
|
||||||
if (address == BANK_SWITCH_HOTSPOT_RAM)
|
if (address == BANK_SWITCH_HOTSPOT_RAM)
|
||||||
changed = bankRAM(value);
|
changed = bankRAM(value);
|
||||||
|
|
||||||
else if (address == BANK_SWITCH_HOTSPOT_ROM)
|
else if (address == BANK_SWITCH_HOTSPOT_ROM)
|
||||||
changed = bankROM(value);
|
changed = bankROM(value);
|
||||||
|
|
||||||
|
if(!(address & 0x1000))
|
||||||
|
{
|
||||||
// Handle TIA space that we claimed above
|
// Handle TIA space that we claimed above
|
||||||
mySystem->tia().poke(address, value);
|
changed = changed || mySystem->tia().poke(address, value);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
uInt32 bankNumber = (address >> RAM_BANK_TO_POWER) & 7; // now 512 byte bank # (ie: 0-7)
|
||||||
|
Int16 whichBankIsThere = bankInUse[bankNumber]; // ROM or RAM bank reference
|
||||||
|
|
||||||
|
if(whichBankIsThere & BITMASK_ROMRAM)
|
||||||
|
{
|
||||||
|
uInt32 byteOffset = address & BITMASK_RAM_BANK;
|
||||||
|
uInt32 baseAddress = ((whichBankIsThere & BIT_BANK_MASK) << RAM_BANK_TO_POWER) + byteOffset;
|
||||||
|
pokeRAM(myRAM[baseAddress], address, value);
|
||||||
|
changed = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return changed;
|
return changed;
|
||||||
}
|
}
|
||||||
|
@ -183,9 +189,7 @@ void CartridgeDASH::bankRAMSlot(uInt16 bank)
|
||||||
|
|
||||||
for (uInt16 addr = start; addr <= end; addr += System::PAGE_SIZE)
|
for (uInt16 addr = start; addr <= end; addr += System::PAGE_SIZE)
|
||||||
{
|
{
|
||||||
if(upper)
|
if(!upper)
|
||||||
access.directPokeBase = &myRAM[startCurrentBank + (addr & (RAM_BANK_SIZE - 1))];
|
|
||||||
else
|
|
||||||
access.directPeekBase = &myRAM[startCurrentBank + (addr & (RAM_BANK_SIZE - 1))];
|
access.directPeekBase = &myRAM[startCurrentBank + (addr & (RAM_BANK_SIZE - 1))];
|
||||||
|
|
||||||
access.codeAccessBase = &myCodeAccessBase[mySize + startCurrentBank + (addr & (RAM_BANK_SIZE - 1))];
|
access.codeAccessBase = &myCodeAccessBase[mySize + startCurrentBank + (addr & (RAM_BANK_SIZE - 1))];
|
||||||
|
|
Loading…
Reference in New Issue