Prompt now shows RAM locations that have changed since the last RAM command

in inverse video.


git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@592 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
urchlay 2005-07-02 17:15:42 +00:00
parent 040a8d7d22
commit 3501378714
4 changed files with 63 additions and 12 deletions

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of // See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES. // this file, and for a DISCLAIMER OF ALL WARRANTIES.
// //
// $Id: Debugger.cxx,v 1.44 2005-07-02 15:31:30 urchlay Exp $ // $Id: Debugger.cxx,v 1.45 2005-07-02 17:15:41 urchlay Exp $
//============================================================================ //============================================================================
#include "bspf.hxx" #include "bspf.hxx"
@ -129,6 +129,9 @@ void Debugger::setConsole(Console* console)
myDebugger = new D6502(mySystem); myDebugger = new D6502(mySystem);
autoLoadSymbols(myOSystem->romFile()); autoLoadSymbols(myOSystem->romFile());
for(int i=0; i<0x80; i++)
myOldRAM[i] = readRAM(i);
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
@ -286,19 +289,35 @@ void Debugger::formatFlags(int f, char *out) {
out[8] = '\0'; out[8] = '\0';
} }
/* Danger: readRAM() and writeRAM() take an *offset* into RAM, *not* an
actual address. This means you don't get to use these to read/write
outside of the RIOT RAM. It also means that e.g. to read location 0x80,
you pass 0 (because 0x80 is the 0th byte of RAM).
However, setRAM() actually uses addresses, not offsets. This means that
setRAM() can poke anywhere in the address space. However, it still can't
change ROM: you use patchROM() for that. setRAM() *can* trigger a bank
switch, if you poke to the "hot spot" for the cartridge.
*/
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
uInt8 Debugger::readRAM(uInt16 addr) uInt8 Debugger::readRAM(uInt16 offset)
{ {
return mySystem->peek(addr + kRamStart); offset &= 0x7f; // there are only 128 bytes
return mySystem->peek(offset + kRamStart);
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void Debugger::writeRAM(uInt16 addr, uInt8 value) void Debugger::writeRAM(uInt16 offset, uInt8 value)
{ {
mySystem->poke(addr + kRamStart, value); offset &= 0x7f; // there are only 128 bytes
mySystem->poke(offset + kRamStart, value);
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
/* Element 0 of args is the address. The remaining elements are the data
to poke, starting at the given address.
*/
const string Debugger::setRAM(IntArray args) { const string Debugger::setRAM(IntArray args) {
char buf[10]; char buf[10];
@ -311,11 +330,18 @@ const string Debugger::setRAM(IntArray args) {
sprintf(buf, "%d", count-1); sprintf(buf, "%d", count-1);
ret += buf; ret += buf;
ret += " location"; ret += " location";
if(count > 2) if(count != 0)
ret += "s"; ret += "s";
return ret; return ret;
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
uInt8 Debugger::oldRAM(uInt8 offset)
{
offset &= 0x7f;
return myOldRAM[offset];
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
const string Debugger::dumpRAM(uInt16 start) const string Debugger::dumpRAM(uInt16 start)
{ {
@ -329,8 +355,14 @@ const string Debugger::dumpRAM(uInt16 start)
for (uInt8 j = 0; j < 0x010; j++) for (uInt8 j = 0; j < 0x010; j++)
{ {
sprintf(buf, "%.2x ", mySystem->peek(start+i+j)); int byte = mySystem->peek(start+i+j);
bool changed = (byte != myOldRAM[i+j]);
if(changed) result += "\177";
sprintf(buf, "%.2x", mySystem->peek(start+i+j));
result += buf; result += buf;
if(changed) result += "\177";
result += " ";
if(j == 0x07) result += "- "; if(j == 0x07) result += "- ";
} }
@ -673,6 +705,7 @@ string Debugger::disassemble(int start, int lines) {
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void Debugger::nextFrame(int frames) { void Debugger::nextFrame(int frames) {
saveRegs();
myOSystem->frameBuffer().advance(frames); myOSystem->frameBuffer().advance(frames);
myBaseDialog->loadConfig(); myBaseDialog->loadConfig();
} }
@ -768,6 +801,9 @@ bool Debugger::patchROM(int addr, int value) {
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void Debugger::saveRegs() { void Debugger::saveRegs() {
for(int i=0; i<0x80; i++) {
myOldRAM[i] = readRAM(i);
}
oldA = getA(); oldA = getA();
oldX = getX(); oldX = getX();
oldY = getY(); oldY = getY();

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of // See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES. // this file, and for a DISCLAIMER OF ALL WARRANTIES.
// //
// $Id: Debugger.hxx,v 1.37 2005-07-02 15:31:30 urchlay Exp $ // $Id: Debugger.hxx,v 1.38 2005-07-02 17:15:41 urchlay Exp $
//============================================================================ //============================================================================
#ifndef DEBUGGER_HXX #ifndef DEBUGGER_HXX
@ -51,7 +51,7 @@ enum {
for all debugging operations in Stella (parser, 6502 debugger, etc). for all debugging operations in Stella (parser, 6502 debugger, etc).
@author Stephen Anthony @author Stephen Anthony
@version $Id: Debugger.hxx,v 1.37 2005-07-02 15:31:30 urchlay Exp $ @version $Id: Debugger.hxx,v 1.38 2005-07-02 17:15:41 urchlay Exp $
*/ */
class Debugger : public DialogContainer class Debugger : public DialogContainer
{ {
@ -240,6 +240,7 @@ class Debugger : public DialogContainer
bool patchROM(int addr, int value); bool patchROM(int addr, int value);
void saveState(int state); void saveState(int state);
void loadState(int state); void loadState(int state);
uInt8 oldRAM(uInt8 address);
protected: protected:
const string invIfChanged(int reg, int oldReg); const string invIfChanged(int reg, int oldReg);
@ -256,6 +257,7 @@ class Debugger : public DialogContainer
PromptWidget *myPrompt; PromptWidget *myPrompt;
TIADebug *myTIAdebug; TIADebug *myTIAdebug;
uInt8 myOldRAM[128];
int oldA; int oldA;
int oldX; int oldX;
int oldY; int oldY;

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of // See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES. // this file, and for a DISCLAIMER OF ALL WARRANTIES.
// //
// $Id: Console.cxx,v 1.63 2005-06-29 13:11:03 stephena Exp $ // $Id: Console.cxx,v 1.64 2005-07-02 17:15:41 urchlay Exp $
//============================================================================ //============================================================================
#include <assert.h> #include <assert.h>
@ -152,6 +152,7 @@ Console::Console(const uInt8* image, uInt32 size, OSystem* osystem)
// Remember what my media source is // Remember what my media source is
myMediaSource = tia; myMediaSource = tia;
myCart = cartridge; myCart = cartridge;
myRiot = m6532;
// Reset, the system to its power-on state // Reset, the system to its power-on state
mySystem->reset(); mySystem->reset();

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of // See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES. // this file, and for a DISCLAIMER OF ALL WARRANTIES.
// //
// $Id: Console.hxx,v 1.36 2005-06-29 13:11:03 stephena Exp $ // $Id: Console.hxx,v 1.37 2005-07-02 17:15:42 urchlay Exp $
//============================================================================ //============================================================================
#ifndef CONSOLE_HXX #ifndef CONSOLE_HXX
@ -31,12 +31,13 @@ class System;
#include "Props.hxx" #include "Props.hxx"
#include "TIA.hxx" #include "TIA.hxx"
#include "Cart.hxx" #include "Cart.hxx"
#include "M6532.hxx"
/** /**
This class represents the entire game console. This class represents the entire game console.
@author Bradford W. Mott @author Bradford W. Mott
@version $Id: Console.hxx,v 1.36 2005-06-29 13:11:03 stephena Exp $ @version $Id: Console.hxx,v 1.37 2005-07-02 17:15:42 urchlay Exp $
*/ */
class Console class Console
{ {
@ -109,6 +110,13 @@ class Console
*/ */
Cartridge& cartridge() const { return *myCart; } Cartridge& cartridge() const { return *myCart; }
/**
Get the 6532 used by the console
@return The 6532 for this console
*/
M6532& riot() const { return *myRiot; }
public: public:
/** /**
Overloaded assignment operator Overloaded assignment operator
@ -238,6 +246,10 @@ class Console
// Pointer to the Cartridge (the debugger needs it) // Pointer to the Cartridge (the debugger needs it)
Cartridge *myCart; Cartridge *myCart;
// Pointer to the 6532 (aka RIOT) (the debugger needs it)
// A RIOT of my own! (...with apologies to The Clash...)
M6532 *myRiot;
}; };
#endif #endif