mirror of
https://github.com/mauiaaron/apple2.git
synced 2025-01-10 23:29:43 +00:00
Improved VM_TRACING syntax
This commit is contained in:
parent
88b7db0387
commit
0ad98602fe
12
src/glue.h
12
src/glue.h
@ -26,11 +26,12 @@
|
|||||||
#define GLUE_C_WRITE(func) \
|
#define GLUE_C_WRITE(func) \
|
||||||
void c__##func(uint16_t ea, uint8_t b); \
|
void c__##func(uint16_t ea, uint8_t b); \
|
||||||
void c_##func(uint16_t ea, uint8_t b) { \
|
void c_##func(uint16_t ea, uint8_t b) { \
|
||||||
extern FILE *test_vm_fp; \
|
|
||||||
if (test_vm_fp && ((ea >= 0xC000) && (ea < 0xD000)) ) { \
|
|
||||||
fprintf(test_vm_fp, "%04X w:%02X %s (%s:%d)\n", ea, b, __FUNCTION__, __FILE__, __LINE__); \
|
|
||||||
} \
|
|
||||||
c__##func(ea, b); \
|
c__##func(ea, b); \
|
||||||
|
extern FILE *test_vm_fp; \
|
||||||
|
if (test_vm_fp && !vm_trace_is_ignored(ea)) { \
|
||||||
|
fprintf(test_vm_fp, "%04X w:%02X %s (%s:%d)\n", ea, b, __FUNCTION__, __FILE__, __LINE__); \
|
||||||
|
fflush(test_vm_fp); \
|
||||||
|
} \
|
||||||
} \
|
} \
|
||||||
void c__##func(uint16_t ea, uint8_t b)
|
void c__##func(uint16_t ea, uint8_t b)
|
||||||
|
|
||||||
@ -39,8 +40,9 @@
|
|||||||
uint8_t c_##func(uint16_t ea) { \
|
uint8_t c_##func(uint16_t ea) { \
|
||||||
uint8_t b = c__##func(ea); \
|
uint8_t b = c__##func(ea); \
|
||||||
extern FILE *test_vm_fp; \
|
extern FILE *test_vm_fp; \
|
||||||
if (test_vm_fp && ((ea >= 0xC000) && (ea < 0xD000)) ) { \
|
if (test_vm_fp && !vm_trace_is_ignored(ea)) { \
|
||||||
fprintf(test_vm_fp, "%04X r:%02X %s (%s:%d)\n", ea, b, __FUNCTION__, __FILE__, __LINE__); \
|
fprintf(test_vm_fp, "%04X r:%02X %s (%s:%d)\n", ea, b, __FUNCTION__, __FILE__, __LINE__); \
|
||||||
|
fflush(test_vm_fp); \
|
||||||
} \
|
} \
|
||||||
return b; \
|
return b; \
|
||||||
} \
|
} \
|
||||||
|
@ -124,9 +124,10 @@ void reinitialize();
|
|||||||
/* vm hooks */
|
/* vm hooks */
|
||||||
|
|
||||||
#if VM_TRACING
|
#if VM_TRACING
|
||||||
void vm_begin_trace(const char *vm_file);
|
void vm_trace_begin(const char *vm_file);
|
||||||
void vm_end_trace(void);
|
void vm_trace_end(void);
|
||||||
void vm_toggle_trace(const char *vm_file);
|
void vm_trace_toggle(const char *vm_file);
|
||||||
|
bool vm_trace_is_ignored(uint16_t ea);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void ram_nop(),
|
void ram_nop(),
|
||||||
|
@ -144,20 +144,20 @@ TEST test_boot_disk_cputrace() {
|
|||||||
PASS();
|
PASS();
|
||||||
}
|
}
|
||||||
|
|
||||||
#define EXPECTED_VM_TRACE_FILE_SIZE 3688453
|
#define EXPECTED_VM_TRACE_FILE_SIZE 2670370
|
||||||
#define EXPECTED_VM_TRACE_SHA "9946B0C5288228535A37475CDAB5C9E685EEDDE9"
|
#define EXPECTED_VM_TRACE_SHA "E808CFF531554AC825A6A2D9E49170887AC9594C"
|
||||||
TEST test_boot_disk_vmtrace() {
|
TEST test_boot_disk_vmtrace() {
|
||||||
char *homedir = getenv("HOME");
|
char *homedir = getenv("HOME");
|
||||||
char *disk = NULL;
|
char *disk = NULL;
|
||||||
asprintf(&disk, "%s/a2_vmtrace.txt", homedir);
|
asprintf(&disk, "%s/a2_vmtrace.txt", homedir);
|
||||||
if (disk) {
|
if (disk) {
|
||||||
unlink(disk);
|
unlink(disk);
|
||||||
vm_begin_trace(disk);
|
vm_trace_begin(disk);
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOT_TO_DOS();
|
BOOT_TO_DOS();
|
||||||
|
|
||||||
vm_end_trace();
|
vm_trace_end();
|
||||||
c_eject_6(0);
|
c_eject_6(0);
|
||||||
|
|
||||||
do {
|
do {
|
||||||
|
28
src/vm.c
28
src/vm.c
@ -115,6 +115,11 @@
|
|||||||
|
|
||||||
#if VM_TRACING
|
#if VM_TRACING
|
||||||
FILE *test_vm_fp = NULL;
|
FILE *test_vm_fp = NULL;
|
||||||
|
|
||||||
|
typedef struct vm_trace_range_t {
|
||||||
|
uint16_t lo;
|
||||||
|
uint16_t hi;
|
||||||
|
} vm_trace_range_t;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
GLUE_C_READ(ram_nop)
|
GLUE_C_READ(ram_nop)
|
||||||
@ -1044,16 +1049,16 @@ void debug_print_softwitches(void) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if VM_TRACING
|
#if VM_TRACING
|
||||||
void vm_begin_trace(const char *vm_file) {
|
void vm_trace_begin(const char *vm_file) {
|
||||||
if (vm_file) {
|
if (vm_file) {
|
||||||
if (test_vm_fp) {
|
if (test_vm_fp) {
|
||||||
vm_end_trace();
|
vm_trace_end();
|
||||||
}
|
}
|
||||||
test_vm_fp = fopen(vm_file, "w");
|
test_vm_fp = fopen(vm_file, "w");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void vm_end_trace(void) {
|
void vm_trace_end(void) {
|
||||||
if (test_vm_fp) {
|
if (test_vm_fp) {
|
||||||
fflush(test_vm_fp);
|
fflush(test_vm_fp);
|
||||||
fclose(test_vm_fp);
|
fclose(test_vm_fp);
|
||||||
@ -1061,12 +1066,23 @@ void vm_end_trace(void) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void vm_toggle_trace(const char *vm_file) {
|
void vm_trace_toggle(const char *vm_file) {
|
||||||
if (test_vm_fp) {
|
if (test_vm_fp) {
|
||||||
vm_end_trace();
|
vm_trace_end();
|
||||||
} else {
|
} else {
|
||||||
vm_begin_trace(vm_file);
|
vm_trace_begin(vm_file);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void vm_trace_ignore(vm_trace_range_t range) {
|
||||||
|
// TODO ...
|
||||||
|
}
|
||||||
|
|
||||||
|
bool vm_trace_is_ignored(uint16_t ea) {
|
||||||
|
if ((ea < 0xC000) || (ea > 0xCFFF)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user