mirror of
https://github.com/hoglet67/AtomBusMon.git
synced 2025-01-05 13:32:26 +00:00
Improved output of regs and memory dumps
Change-Id: Ib0b7474a198b19a8aba0523f9351edf519941596
This commit is contained in:
parent
e075d54924
commit
6d732a01ec
@ -113,7 +113,7 @@ char *triggerStrings[NUM_TRIGGERS] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
#define VERSION "0.24"
|
#define VERSION "0.25"
|
||||||
|
|
||||||
#ifdef EMBEDDED_6502
|
#ifdef EMBEDDED_6502
|
||||||
#define NUM_CMDS 24
|
#define NUM_CMDS 24
|
||||||
@ -131,6 +131,8 @@ long instructions = 1;
|
|||||||
|
|
||||||
unsigned int memAddr = 0;
|
unsigned int memAddr = 0;
|
||||||
|
|
||||||
|
char statusString[8] = "NV-BDIZC";
|
||||||
|
|
||||||
unsigned int breakpoints[MAXBKPTS] = {
|
unsigned int breakpoints[MAXBKPTS] = {
|
||||||
0,
|
0,
|
||||||
0,
|
0,
|
||||||
@ -468,25 +470,46 @@ void doCmdReset(char *params) {
|
|||||||
|
|
||||||
#ifdef EMBEDDED_6502
|
#ifdef EMBEDDED_6502
|
||||||
void doCmdRegs(char *params) {
|
void doCmdRegs(char *params) {
|
||||||
log0("A=%02X; ", hwRead8(OFFSET_REG_A));
|
int i;
|
||||||
log0("X=%02X; ", hwRead8(OFFSET_REG_X));
|
log0("6502 Registers:\n");
|
||||||
log0("Y=%02X; ", hwRead8(OFFSET_REG_Y));
|
log0(" A=%02X X=%02X Y=%02X SP=01%02X PC=%04X\n",
|
||||||
log0("P=%02X; ", hwRead8(OFFSET_REG_P));
|
hwRead8(OFFSET_REG_A),
|
||||||
log0("SP=01%02X; ", hwRead8(OFFSET_REG_SPL));
|
hwRead8(OFFSET_REG_X),
|
||||||
log0("PC=%04X\n", hwRead16(OFFSET_REG_PCL));
|
hwRead8(OFFSET_REG_Y),
|
||||||
|
hwRead8(OFFSET_REG_SPL),
|
||||||
|
hwRead16(OFFSET_REG_PCL));
|
||||||
|
unsigned int p = hwRead8(OFFSET_REG_P);
|
||||||
|
char *sp = statusString;
|
||||||
|
log0(" P=%02X ", p);
|
||||||
|
for (i = 0; i <= 7; i++) {
|
||||||
|
log0("%c", ((p & 128) ? (*sp) : '-'));
|
||||||
|
p <<= 1;
|
||||||
|
sp++;
|
||||||
|
}
|
||||||
|
log0("\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
void doCmdMem(char *params) {
|
void doCmdMem(char *params) {
|
||||||
int i;
|
int i, j;
|
||||||
|
unsigned int row[16];
|
||||||
sscanf(params, "%x", &memAddr);
|
sscanf(params, "%x", &memAddr);
|
||||||
for (i = 0; i < 0x100; i++) {
|
for (i = 0; i < 0x100; i+= 16) {
|
||||||
if ((i & 15) == 0) {
|
for (j = 0; j < 16; j++) {
|
||||||
log0("%04X ", memAddr + i);
|
row[j] = readMem(memAddr + i + j);
|
||||||
}
|
}
|
||||||
log0("%02X ", readMem(memAddr + i));
|
log0("%04X ", memAddr + i);
|
||||||
if ((i & 15) == 15) {
|
for (j = 0; j < 16; j++) {
|
||||||
log0("\n");
|
log0("%02X ", row[j]);
|
||||||
}
|
}
|
||||||
|
log0(" ");
|
||||||
|
for (j = 0; j < 16; j++) {
|
||||||
|
unsigned int c = row[j];
|
||||||
|
if (c < 32 || c > 126) {
|
||||||
|
c = '.';
|
||||||
|
}
|
||||||
|
log0("%c", c);
|
||||||
|
}
|
||||||
|
log0("\n");
|
||||||
}
|
}
|
||||||
memAddr += 0x100;
|
memAddr += 0x100;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user