mirror of https://github.com/stella-emu/stella.git
differentiate ROM read/write access (done for Atari standard and 3E bankswitching)
This commit is contained in:
parent
96131e2f7f
commit
8b550a3a11
|
@ -1347,7 +1347,7 @@ string CartDebug::saveRom()
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
string CartDebug::saveAccessFile()
|
string CartDebug::saveAccessFile()
|
||||||
{
|
{
|
||||||
const string& rom = myConsole.properties().get(PropType::Cart_Name) + ".cvs";
|
const string& rom = myConsole.properties().get(PropType::Cart_Name) + ".csv";
|
||||||
FilesystemNode node(myOSystem.defaultSaveDir() + rom);
|
FilesystemNode node(myOSystem.defaultSaveDir() + rom);
|
||||||
ofstream out(node.getPath());
|
ofstream out(node.getPath());
|
||||||
|
|
||||||
|
|
|
@ -142,19 +142,32 @@ void Cartridge::createRomAccessArrays(size_t size)
|
||||||
string Cartridge::getAccessCounters() const
|
string Cartridge::getAccessCounters() const
|
||||||
{
|
{
|
||||||
ostringstream out;
|
ostringstream out;
|
||||||
|
size_t romSize;
|
||||||
|
uInt32 offset = 0;
|
||||||
|
|
||||||
|
getImage(romSize);
|
||||||
|
|
||||||
for(uInt16 bank = 0; bank < bankCount(); ++bank)
|
for(uInt16 bank = 0; bank < bankCount(); ++bank)
|
||||||
{
|
{
|
||||||
uInt32 offset = bank * bankSize();
|
|
||||||
uInt16 origin = bankOrigin(bank);
|
uInt16 origin = bankOrigin(bank);
|
||||||
|
uInt16 bankSize = this->bankSize(bank);
|
||||||
|
|
||||||
out << "Bank " << bank << " / 0.." << bankCount() - 1 << ":\n";
|
out << "Bank " << bank << " / 0.." << bankCount() - 1 << " reads:\n";
|
||||||
for(uInt16 addr = 0; addr < bankSize(); ++addr)
|
for(uInt16 addr = 0; addr < bankSize; ++addr)
|
||||||
{
|
{
|
||||||
out << Common::Base::HEX4 << (addr | origin) << ","
|
out << Common::Base::HEX4 << (addr | origin) << ","
|
||||||
<< Common::Base::toString(myRomAccessBase[offset + addr], Common::Base::Fmt::_10_8) << ", ";
|
<< Common::Base::toString(myRomAccessCounter[offset + addr], Common::Base::Fmt::_10_8) << ", ";
|
||||||
}
|
}
|
||||||
out << "\n";
|
out << "\n";
|
||||||
|
out << "Bank " << bank << " / 0.." << bankCount() - 1 << " writes:\n";
|
||||||
|
for(uInt16 addr = 0; addr < bankSize; ++addr)
|
||||||
|
{
|
||||||
|
out << Common::Base::HEX4 << (addr | origin) << ","
|
||||||
|
<< Common::Base::toString(myRomAccessCounter[offset + addr + romSize], Common::Base::Fmt::_10_8) << ", ";
|
||||||
|
}
|
||||||
|
out << "\n";
|
||||||
|
|
||||||
|
offset += bankSize;
|
||||||
}
|
}
|
||||||
|
|
||||||
return out.str();
|
return out.str();
|
||||||
|
@ -165,20 +178,30 @@ uInt16 Cartridge::bankOrigin(uInt16 bank) const
|
||||||
{
|
{
|
||||||
// isolate the high 3 address bits, count them and
|
// isolate the high 3 address bits, count them and
|
||||||
// select the most frequent to define the bank origin
|
// select the most frequent to define the bank origin
|
||||||
std::array<uInt16, 8> count;
|
const int intervals = 0x8000 / 0x100;
|
||||||
uInt32 offset = bank * bankSize();
|
uInt32 offset = bank * bankSize();
|
||||||
|
//uInt16 addrMask = (4_KB - 1) & ~(bankSize(bank) - 1);
|
||||||
|
//int addrShift = 0;
|
||||||
|
std::array<uInt16, intervals> count; // up to 128 256 byte interval origins
|
||||||
|
|
||||||
|
|
||||||
|
//if(addrMask)
|
||||||
|
// addrShift = log(addrMask) / log(2);
|
||||||
|
//addrMask;
|
||||||
|
|
||||||
count.fill(0);
|
count.fill(0);
|
||||||
|
|
||||||
for(uInt16 addr = 0x0000; addr < bankSize(bank); ++addr)
|
for(uInt16 addr = 0x0000; addr < bankSize(bank); ++addr)
|
||||||
{
|
{
|
||||||
Device::AccessFlags flags = myRomAccessBase[offset + addr];
|
Device::AccessFlags flags = myRomAccessBase[offset + addr];
|
||||||
// only count really accessed addresses
|
// only count really accessed addresses
|
||||||
if (flags & ~Device::ROW)
|
if(flags & ~Device::ROW)
|
||||||
|
{
|
||||||
|
//uInt16 addrBit = addr >> addrShift;
|
||||||
count[(flags & Device::HADDR) >> 13]++;
|
count[(flags & Device::HADDR) >> 13]++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
uInt16 max = 0, maxIdx = 0;
|
uInt16 max = 0, maxIdx = 0;
|
||||||
for(int idx = 0; idx < 8; ++idx)
|
for(int idx = 0; idx < intervals; ++idx)
|
||||||
{
|
{
|
||||||
if(count[idx] > max)
|
if(count[idx] > max)
|
||||||
{
|
{
|
||||||
|
@ -186,7 +209,7 @@ uInt16 Cartridge::bankOrigin(uInt16 bank) const
|
||||||
maxIdx = idx;
|
maxIdx = idx;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return maxIdx << 13 | 0x1000;
|
return maxIdx << 13 | 0x1000 | (offset & 0xfff);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -77,6 +77,8 @@ void Cartridge2K::install(System& system)
|
||||||
{
|
{
|
||||||
access.directPeekBase = &myImage[addr & myMask];
|
access.directPeekBase = &myImage[addr & myMask];
|
||||||
access.romAccessBase = &myRomAccessBase[addr & myMask];
|
access.romAccessBase = &myRomAccessBase[addr & myMask];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[addr & 0x0FFF];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[(addr & 0x0FFF) + mySize];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -60,6 +60,8 @@ void Cartridge3E::install(System& system)
|
||||||
{
|
{
|
||||||
access.directPeekBase = &myImage[(mySize - 2048) + (addr & 0x07FF)];
|
access.directPeekBase = &myImage[(mySize - 2048) + (addr & 0x07FF)];
|
||||||
access.romAccessBase = &myRomAccessBase[(mySize - 2048) + (addr & 0x07FF)];
|
access.romAccessBase = &myRomAccessBase[(mySize - 2048) + (addr & 0x07FF)];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[(mySize - 2048) + (addr & 0x07FF)];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[(mySize - 2048) + (addr & 0x07FF) + mySize];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -159,6 +161,8 @@ bool Cartridge3E::bank(uInt16 bank)
|
||||||
{
|
{
|
||||||
access.directPeekBase = &myImage[offset + (addr & 0x07FF)];
|
access.directPeekBase = &myImage[offset + (addr & 0x07FF)];
|
||||||
access.romAccessBase = &myRomAccessBase[offset + (addr & 0x07FF)];
|
access.romAccessBase = &myRomAccessBase[offset + (addr & 0x07FF)];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[offset + (addr & 0x07FF)];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[offset + (addr & 0x07FF) + mySize];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -178,6 +182,8 @@ bool Cartridge3E::bank(uInt16 bank)
|
||||||
{
|
{
|
||||||
access.directPeekBase = &myRAM[offset + (addr & 0x03FF)];
|
access.directPeekBase = &myRAM[offset + (addr & 0x03FF)];
|
||||||
access.romAccessBase = &myRomAccessBase[mySize + offset + (addr & 0x03FF)];
|
access.romAccessBase = &myRomAccessBase[mySize + offset + (addr & 0x03FF)];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[mySize + offset + (addr & 0x03FF)];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[mySize + offset + (addr & 0x03FF) + mySize];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -190,6 +196,8 @@ bool Cartridge3E::bank(uInt16 bank)
|
||||||
for(uInt16 addr = 0x1400; addr < 0x1800; addr += System::PAGE_SIZE)
|
for(uInt16 addr = 0x1400; addr < 0x1800; addr += System::PAGE_SIZE)
|
||||||
{
|
{
|
||||||
access.romAccessBase = &myRomAccessBase[mySize + offset + (addr & 0x03FF)];
|
access.romAccessBase = &myRomAccessBase[mySize + offset + (addr & 0x03FF)];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[mySize + offset + (addr & 0x03FF)];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[mySize + offset + (addr & 0x03FF) + mySize];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -47,7 +47,8 @@ void Cartridge4K::install(System& system)
|
||||||
{
|
{
|
||||||
access.directPeekBase = &myImage[addr & 0x0FFF];
|
access.directPeekBase = &myImage[addr & 0x0FFF];
|
||||||
access.romAccessBase = &myRomAccessBase[addr & 0x0FFF];
|
access.romAccessBase = &myRomAccessBase[addr & 0x0FFF];
|
||||||
access.romAccessCounter = &myRomAccessCounter[addr & 0x0FFF];
|
access.romPeekCounter = &myRomAccessCounter[addr & 0x0FFF];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[(addr & 0x0FFF) + myImage.size()];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -89,6 +89,8 @@ bool CartridgeF4::bank(uInt16 bank)
|
||||||
addr += System::PAGE_SIZE)
|
addr += System::PAGE_SIZE)
|
||||||
{
|
{
|
||||||
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF) + myImage.size()];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -98,6 +100,8 @@ bool CartridgeF4::bank(uInt16 bank)
|
||||||
{
|
{
|
||||||
access.directPeekBase = &myImage[myBankOffset + (addr & 0x0FFF)];
|
access.directPeekBase = &myImage[myBankOffset + (addr & 0x0FFF)];
|
||||||
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF) + myImage.size()];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
return myBankChanged = true;
|
return myBankChanged = true;
|
||||||
|
|
|
@ -52,6 +52,8 @@ void CartridgeF4SC::install(System& system)
|
||||||
for(uInt16 addr = 0x1000; addr < 0x1080; addr += System::PAGE_SIZE)
|
for(uInt16 addr = 0x1000; addr < 0x1080; addr += System::PAGE_SIZE)
|
||||||
{
|
{
|
||||||
access.romAccessBase = &myRomAccessBase[addr & 0x007F];
|
access.romAccessBase = &myRomAccessBase[addr & 0x007F];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[addr & 0x007F];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[(addr & 0x07F) + myImage.size()];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,6 +63,8 @@ void CartridgeF4SC::install(System& system)
|
||||||
{
|
{
|
||||||
access.directPeekBase = &myRAM[addr & 0x007F];
|
access.directPeekBase = &myRAM[addr & 0x007F];
|
||||||
access.romAccessBase = &myRomAccessBase[0x80 + (addr & 0x007F)];
|
access.romAccessBase = &myRomAccessBase[0x80 + (addr & 0x007F)];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[0x80 + (addr & 0x007F)];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[0x80 + (addr & 0x007F) + myImage.size()];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -128,6 +132,8 @@ bool CartridgeF4SC::bank(uInt16 bank)
|
||||||
addr += System::PAGE_SIZE)
|
addr += System::PAGE_SIZE)
|
||||||
{
|
{
|
||||||
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF) + myImage.size()];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -137,6 +143,8 @@ bool CartridgeF4SC::bank(uInt16 bank)
|
||||||
{
|
{
|
||||||
access.directPeekBase = &myImage[myBankOffset + (addr & 0x0FFF)];
|
access.directPeekBase = &myImage[myBankOffset + (addr & 0x0FFF)];
|
||||||
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF) + myImage.size()];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
return myBankChanged = true;
|
return myBankChanged = true;
|
||||||
|
|
|
@ -129,6 +129,8 @@ bool CartridgeF6::bank(uInt16 bank)
|
||||||
addr += System::PAGE_SIZE)
|
addr += System::PAGE_SIZE)
|
||||||
{
|
{
|
||||||
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF) + myImage.size()];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -138,6 +140,8 @@ bool CartridgeF6::bank(uInt16 bank)
|
||||||
{
|
{
|
||||||
access.directPeekBase = &myImage[myBankOffset + (addr & 0x0FFF)];
|
access.directPeekBase = &myImage[myBankOffset + (addr & 0x0FFF)];
|
||||||
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF) + myImage.size()];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
return myBankChanged = true;
|
return myBankChanged = true;
|
||||||
|
|
|
@ -52,6 +52,8 @@ void CartridgeF6SC::install(System& system)
|
||||||
for(uInt16 addr = 0x1000; addr < 0x1080; addr += System::PAGE_SIZE)
|
for(uInt16 addr = 0x1000; addr < 0x1080; addr += System::PAGE_SIZE)
|
||||||
{
|
{
|
||||||
access.romAccessBase = &myRomAccessBase[addr & 0x007F];
|
access.romAccessBase = &myRomAccessBase[addr & 0x007F];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[addr & 0x007F];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[(addr & 0x07F) + myImage.size()];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,6 +63,8 @@ void CartridgeF6SC::install(System& system)
|
||||||
{
|
{
|
||||||
access.directPeekBase = &myRAM[addr & 0x007F];
|
access.directPeekBase = &myRAM[addr & 0x007F];
|
||||||
access.romAccessBase = &myRomAccessBase[0x80 + (addr & 0x007F)];
|
access.romAccessBase = &myRomAccessBase[0x80 + (addr & 0x007F)];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[0x80 + (addr & 0x007F)];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[0x80 + (addr & 0x007F) + myImage.size()];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -168,6 +172,8 @@ bool CartridgeF6SC::bank(uInt16 bank)
|
||||||
addr += System::PAGE_SIZE)
|
addr += System::PAGE_SIZE)
|
||||||
{
|
{
|
||||||
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF) + myImage.size()];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -177,6 +183,8 @@ bool CartridgeF6SC::bank(uInt16 bank)
|
||||||
{
|
{
|
||||||
access.directPeekBase = &myImage[myBankOffset + (addr & 0x0FFF)];
|
access.directPeekBase = &myImage[myBankOffset + (addr & 0x0FFF)];
|
||||||
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF) + myImage.size()];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
return myBankChanged = true;
|
return myBankChanged = true;
|
||||||
|
|
|
@ -110,6 +110,8 @@ bool CartridgeF8::bank(uInt16 bank)
|
||||||
addr += System::PAGE_SIZE)
|
addr += System::PAGE_SIZE)
|
||||||
{
|
{
|
||||||
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[myBankOffset + addr & 0x0FFF];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[myBankOffset + addr & 0x0FFF + myImage.size()];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -119,6 +121,8 @@ bool CartridgeF8::bank(uInt16 bank)
|
||||||
{
|
{
|
||||||
access.directPeekBase = &myImage[myBankOffset + (addr & 0x0FFF)];
|
access.directPeekBase = &myImage[myBankOffset + (addr & 0x0FFF)];
|
||||||
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[addr & 0x0FFF];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[addr & 0x0FFF + myImage.size()];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
return myBankChanged = true;
|
return myBankChanged = true;
|
||||||
|
|
|
@ -52,6 +52,8 @@ void CartridgeF8SC::install(System& system)
|
||||||
for(uInt16 addr = 0x1000; addr < 0x1080; addr += System::PAGE_SIZE)
|
for(uInt16 addr = 0x1000; addr < 0x1080; addr += System::PAGE_SIZE)
|
||||||
{
|
{
|
||||||
access.romAccessBase = &myRomAccessBase[addr & 0x007F];
|
access.romAccessBase = &myRomAccessBase[addr & 0x007F];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[addr & 0x007F];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[(addr & 0x07F) + myImage.size()];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,6 +63,8 @@ void CartridgeF8SC::install(System& system)
|
||||||
{
|
{
|
||||||
access.directPeekBase = &myRAM[addr & 0x007F];
|
access.directPeekBase = &myRAM[addr & 0x007F];
|
||||||
access.romAccessBase = &myRomAccessBase[0x80 + (addr & 0x007F)];
|
access.romAccessBase = &myRomAccessBase[0x80 + (addr & 0x007F)];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[0x80 + (addr & 0x007F)];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[0x80 + (addr & 0x007F) + myImage.size()];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -148,6 +152,8 @@ bool CartridgeF8SC::bank(uInt16 bank)
|
||||||
addr += System::PAGE_SIZE)
|
addr += System::PAGE_SIZE)
|
||||||
{
|
{
|
||||||
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF) + myImage.size()];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -157,6 +163,8 @@ bool CartridgeF8SC::bank(uInt16 bank)
|
||||||
{
|
{
|
||||||
access.directPeekBase = &myImage[myBankOffset + (addr & 0x0FFF)];
|
access.directPeekBase = &myImage[myBankOffset + (addr & 0x0FFF)];
|
||||||
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
access.romAccessBase = &myRomAccessBase[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPeekCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF)];
|
||||||
|
access.romPokeCounter = &myRomAccessCounter[myBankOffset + (addr & 0x0FFF) + myImage.size()];
|
||||||
mySystem->setPageAccess(addr, access);
|
mySystem->setPageAccess(addr, access);
|
||||||
}
|
}
|
||||||
return myBankChanged = true;
|
return myBankChanged = true;
|
||||||
|
|
|
@ -146,13 +146,6 @@ class Device : public Serializable
|
||||||
*/
|
*/
|
||||||
virtual void setAccessFlags(uInt16 address, AccessFlags flags) { }
|
virtual void setAccessFlags(uInt16 address, AccessFlags flags) { }
|
||||||
|
|
||||||
/**
|
|
||||||
Query the given address for its access counter
|
|
||||||
|
|
||||||
@param address The address to query for
|
|
||||||
*/
|
|
||||||
virtual AccessCounter getAccessCounter(uInt16 address) const { return 0; }
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Increase the given address's access counter
|
Increase the given address's access counter
|
||||||
|
|
||||||
|
|
|
@ -497,17 +497,6 @@ void M6532::setAccessFlags(uInt16 address, Device::AccessFlags flags)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
Device::AccessCounter M6532::getAccessCounter(uInt16 address) const
|
|
||||||
{
|
|
||||||
if (address & IO_BIT)
|
|
||||||
return myIOAccessCounter[address & IO_MASK];
|
|
||||||
else if (address & STACK_BIT)
|
|
||||||
return myStackAccessCounter[address & STACK_MASK];
|
|
||||||
else
|
|
||||||
return myRAMAccessCounter[address & RAM_MASK];
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void M6532::increaseAccessCounter(uInt16 address, bool isWrite)
|
void M6532::increaseAccessCounter(uInt16 address, bool isWrite)
|
||||||
{
|
{
|
||||||
|
|
|
@ -169,13 +169,6 @@ class M6532 : public Device
|
||||||
*/
|
*/
|
||||||
void setAccessFlags(uInt16 address, Device::AccessFlags flags) override;
|
void setAccessFlags(uInt16 address, Device::AccessFlags flags) override;
|
||||||
|
|
||||||
/**
|
|
||||||
Query the given address for its access counter
|
|
||||||
|
|
||||||
@param address The address to query for
|
|
||||||
*/
|
|
||||||
Device::AccessCounter getAccessCounter(uInt16 address) const override;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Increase the given address's access counter
|
Increase the given address's access counter
|
||||||
|
|
||||||
|
|
|
@ -110,10 +110,11 @@ uInt8 System::peek(uInt16 addr, Device::AccessFlags flags)
|
||||||
else
|
else
|
||||||
access.device->setAccessFlags(addr, flags);
|
access.device->setAccessFlags(addr, flags);
|
||||||
// Increase access counter
|
// Increase access counter
|
||||||
if(access.romAccessCounter)
|
if (flags != Device::NONE)
|
||||||
*(access.romAccessCounter + (addr & PAGE_MASK)) += 1;
|
if(access.romPeekCounter)
|
||||||
else
|
*(access.romPeekCounter + (addr & PAGE_MASK)) += 1;
|
||||||
access.device->increaseAccessCounter(addr);
|
else
|
||||||
|
access.device->increaseAccessCounter(addr);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// See if this page uses direct accessing or not
|
// See if this page uses direct accessing or not
|
||||||
|
@ -144,10 +145,11 @@ void System::poke(uInt16 addr, uInt8 value, Device::AccessFlags flags)
|
||||||
else
|
else
|
||||||
access.device->setAccessFlags(addr, flags);
|
access.device->setAccessFlags(addr, flags);
|
||||||
// Increase access counter
|
// Increase access counter
|
||||||
if(access.romAccessCounter)
|
if (flags != Device::NONE)
|
||||||
*(access.romAccessCounter + (addr & PAGE_MASK)) += 1;
|
if(access.romPokeCounter)
|
||||||
else
|
*(access.romPokeCounter + (addr & PAGE_MASK)) += 1;
|
||||||
access.device->increaseAccessCounter(addr, true);
|
else
|
||||||
|
access.device->increaseAccessCounter(addr, true);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// See if this page uses direct accessing or not
|
// See if this page uses direct accessing or not
|
||||||
|
@ -192,28 +194,30 @@ void System::setAccessFlags(uInt16 addr, Device::AccessFlags flags)
|
||||||
access.device->setAccessFlags(addr, flags);
|
access.device->setAccessFlags(addr, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
Device::AccessCounter System::getAccessCounter(uInt16 addr) const
|
|
||||||
{
|
|
||||||
const PageAccess& access = getPageAccess(addr);
|
|
||||||
|
|
||||||
if(access.romAccessCounter)
|
|
||||||
return *(access.romAccessCounter + (addr & PAGE_MASK));
|
|
||||||
else
|
|
||||||
return access.device->getAccessCounter(addr);
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void System::increaseAccessCounter(uInt16 addr, bool isWrite)
|
void System::increaseAccessCounter(uInt16 addr, bool isWrite)
|
||||||
{
|
{
|
||||||
const PageAccess& access = getPageAccess(addr);
|
const PageAccess& access = getPageAccess(addr);
|
||||||
|
|
||||||
if(access.romAccessCounter)
|
|
||||||
*(access.romAccessCounter + (addr & PAGE_MASK)) += 1;
|
|
||||||
else
|
|
||||||
access.device->increaseAccessCounter(addr, isWrite);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
if(isWrite)
|
||||||
|
{
|
||||||
|
if(access.romPokeCounter)
|
||||||
|
{
|
||||||
|
*(access.romPokeCounter + (addr & PAGE_MASK)) += 1;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if(access.romPeekCounter)
|
||||||
|
{
|
||||||
|
*(access.romPeekCounter + (addr & PAGE_MASK)) += 1;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
access.device->increaseAccessCounter(addr, isWrite);
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
|
|
@ -240,13 +240,6 @@ class System : public Serializable
|
||||||
Device::AccessFlags getAccessFlags(uInt16 address) const;
|
Device::AccessFlags getAccessFlags(uInt16 address) const;
|
||||||
void setAccessFlags(uInt16 address, Device::AccessFlags flags);
|
void setAccessFlags(uInt16 address, Device::AccessFlags flags);
|
||||||
|
|
||||||
/**
|
|
||||||
Query the given address for its access counter
|
|
||||||
|
|
||||||
@param address The address to query for
|
|
||||||
*/
|
|
||||||
Device::AccessCounter getAccessCounter(uInt16 address) const;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Increase the given address's access counter
|
Increase the given address's access counter
|
||||||
|
|
||||||
|
@ -302,7 +295,12 @@ class System : public Serializable
|
||||||
/**
|
/**
|
||||||
TODO
|
TODO
|
||||||
*/
|
*/
|
||||||
Device::AccessCounter* romAccessCounter{nullptr};
|
Device::AccessCounter* romPeekCounter{nullptr};
|
||||||
|
|
||||||
|
/**
|
||||||
|
TODO
|
||||||
|
*/
|
||||||
|
Device::AccessCounter* romPokeCounter{nullptr};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Pointer to the device associated with this page or to the system's
|
Pointer to the device associated with this page or to the system's
|
||||||
|
|
|
@ -1980,12 +1980,6 @@ void TIA::setAccessFlags(uInt16 address, Device::AccessFlags flags)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
Device::AccessCounter TIA::getAccessCounter(uInt16 address) const
|
|
||||||
{
|
|
||||||
return myAccessCounter[address & TIA_MASK];
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void TIA::increaseAccessCounter(uInt16 address, bool isWrite)
|
void TIA::increaseAccessCounter(uInt16 address, bool isWrite)
|
||||||
{
|
{
|
||||||
|
|
|
@ -703,13 +703,6 @@ class TIA : public Device
|
||||||
*/
|
*/
|
||||||
void setAccessFlags(uInt16 address, Device::AccessFlags flags) override;
|
void setAccessFlags(uInt16 address, Device::AccessFlags flags) override;
|
||||||
|
|
||||||
/**
|
|
||||||
Query the given address for its access counter
|
|
||||||
|
|
||||||
@param address The address to query for
|
|
||||||
*/
|
|
||||||
Device::AccessCounter getAccessCounter(uInt16 address) const override;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Increase the given address's access counter
|
Increase the given address's access counter
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue