mirror of https://github.com/stella-emu/stella.git
Writes to TIA GFX registers are now seen in the ROM disassembly.
This commit is contained in:
parent
61155ace46
commit
6d33db8646
|
@ -23,6 +23,10 @@
|
||||||
#include "Console.hxx"
|
#include "Console.hxx"
|
||||||
#include "Types.hxx"
|
#include "Types.hxx"
|
||||||
|
|
||||||
|
#ifdef DEBUGGER_SUPPORT
|
||||||
|
#include "CartDebug.hxx"
|
||||||
|
#endif
|
||||||
|
|
||||||
enum CollisionMask: uInt32 {
|
enum CollisionMask: uInt32 {
|
||||||
player0 = 0b0111110000000000,
|
player0 = 0b0111110000000000,
|
||||||
player1 = 0b0100001111000000,
|
player1 = 0b0100001111000000,
|
||||||
|
@ -408,16 +412,37 @@ bool TIA::poke(uInt16 address, uInt8 value)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case PF0:
|
case PF0:
|
||||||
|
{
|
||||||
myDelayQueue.push(PF0, value, Delay::pf);
|
myDelayQueue.push(PF0, value, Delay::pf);
|
||||||
|
#ifdef DEBUGGER_SUPPORT
|
||||||
|
uInt16 dataAddr = mySystem->m6502().lastDataAddressForPoke();
|
||||||
|
if(dataAddr)
|
||||||
|
mySystem->setAccessFlags(dataAddr, CartDebug::PGFX);
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case PF1:
|
case PF1:
|
||||||
|
{
|
||||||
myDelayQueue.push(PF1, value, Delay::pf);
|
myDelayQueue.push(PF1, value, Delay::pf);
|
||||||
|
#ifdef DEBUGGER_SUPPORT
|
||||||
|
uInt16 dataAddr = mySystem->m6502().lastDataAddressForPoke();
|
||||||
|
if(dataAddr)
|
||||||
|
mySystem->setAccessFlags(dataAddr, CartDebug::PGFX);
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case PF2:
|
case PF2:
|
||||||
|
{
|
||||||
myDelayQueue.push(PF2, value, Delay::pf);
|
myDelayQueue.push(PF2, value, Delay::pf);
|
||||||
|
#ifdef DEBUGGER_SUPPORT
|
||||||
|
uInt16 dataAddr = mySystem->m6502().lastDataAddressForPoke();
|
||||||
|
if(dataAddr)
|
||||||
|
mySystem->setAccessFlags(dataAddr, CartDebug::PGFX);
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case ENAM0:
|
case ENAM0:
|
||||||
myLinesSinceChange = 0;
|
myLinesSinceChange = 0;
|
||||||
|
@ -474,16 +499,30 @@ bool TIA::poke(uInt16 address, uInt8 value)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case GRP0:
|
case GRP0:
|
||||||
|
{
|
||||||
myDelayQueue.push(GRP0, value, Delay::grp);
|
myDelayQueue.push(GRP0, value, Delay::grp);
|
||||||
myDelayQueue.push(DummyRegisters::shuffleP1, 0, Delay::shufflePlayer);
|
myDelayQueue.push(DummyRegisters::shuffleP1, 0, Delay::shufflePlayer);
|
||||||
|
#ifdef DEBUGGER_SUPPORT
|
||||||
|
uInt16 dataAddr = mySystem->m6502().lastDataAddressForPoke();
|
||||||
|
if(dataAddr)
|
||||||
|
mySystem->setAccessFlags(dataAddr, CartDebug::GFX);
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case GRP1:
|
case GRP1:
|
||||||
|
{
|
||||||
myLinesSinceChange = 0;
|
myLinesSinceChange = 0;
|
||||||
myDelayQueue.push(GRP1, value, Delay::grp);
|
myDelayQueue.push(GRP1, value, Delay::grp);
|
||||||
myDelayQueue.push(DummyRegisters::shuffleP0, 0, Delay::shufflePlayer);
|
myDelayQueue.push(DummyRegisters::shuffleP0, 0, Delay::shufflePlayer);
|
||||||
myBall.shuffleStatus();
|
myBall.shuffleStatus();
|
||||||
|
#ifdef DEBUGGER_SUPPORT
|
||||||
|
uInt16 dataAddr = mySystem->m6502().lastDataAddressForPoke();
|
||||||
|
if(dataAddr)
|
||||||
|
mySystem->setAccessFlags(dataAddr, CartDebug::GFX);
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case RESP0:
|
case RESP0:
|
||||||
myLinesSinceChange = 0;
|
myLinesSinceChange = 0;
|
||||||
|
|
Loading…
Reference in New Issue