1
0
mirror of https://github.com/kanjitalk755/macemu.git synced 2025-01-16 13:30:31 +00:00

Merge pull request from rickyzhang82/pr-enhance-rom-break-point

Enhance ROM break point feature.
This commit is contained in:
asvitkine 2017-10-06 21:32:14 -04:00 committed by GitHub
commit 8d53921b20
5 changed files with 93 additions and 49 deletions

@ -24,6 +24,7 @@
#include <stdlib.h> #include <stdlib.h>
#include <signal.h> #include <signal.h>
#include <errno.h> #include <errno.h>
#include <sstream>
#ifdef USE_SDL #ifdef USE_SDL
# include <SDL.h> # include <SDL.h>
@ -371,7 +372,8 @@ static void usage(const char *prg_name)
"\nUnix options:\n" "\nUnix options:\n"
" --config FILE\n read/write configuration from/to FILE\n" " --config FILE\n read/write configuration from/to FILE\n"
" --display STRING\n X display to use\n" " --display STRING\n X display to use\n"
" --break ADDRESS\n set ROM breakpoint\n" " --break ADDRESS\n set ROM breakpoint in hexadecimal\n"
" --loadbreak FILE\n load breakpoint from FILE\n"
" --rominfo\n dump ROM information\n", prg_name " --rominfo\n dump ROM information\n", prg_name
); );
LoadPrefs(NULL); // read the prefs file so PrefsPrintUsage() will print the correct default values LoadPrefs(NULL); // read the prefs file so PrefsPrintUsage() will print the correct default values
@ -413,9 +415,17 @@ int main(int argc, char **argv)
} else if (strcmp(argv[i], "--break") == 0) { } else if (strcmp(argv[i], "--break") == 0) {
argv[i++] = NULL; argv[i++] = NULL;
if (i < argc) { if (i < argc) {
ROMBreakpoint = strtol(argv[i], NULL, 0); std::stringstream ss;
ss << std::hex << argv[i];
ss >> ROMBreakpoint;
argv[i] = NULL; argv[i] = NULL;
} }
#ifdef ENABLE_MON
} else if (strcmp(argv[i], "--loadbreak") == 0) {
argv[i++] = NULL;
if (i < argc)
mon_load_break_point(argv[i]);
#endif
} else if (strcmp(argv[i], "--config") == 0) { } else if (strcmp(argv[i], "--config") == 0) {
argv[i++] = NULL; argv[i++] = NULL;
if (i < argc) { if (i < argc) {

@ -32,6 +32,11 @@
#include "video.h" #include "video.h"
#include "extfs.h" #include "extfs.h"
#include "prefs.h" #include "prefs.h"
#if ENABLE_MON
#include "mon.h"
#endif
#include "rom_patches.h" #include "rom_patches.h"
#define DEBUG 0 #define DEBUG 0
@ -1678,8 +1683,14 @@ bool PatchROM(void)
// Install breakpoint // Install breakpoint
if (ROMBreakpoint) { if (ROMBreakpoint) {
#if ENABLE_MON
mon_add_break_point(ROMBaseMac + ROMBreakpoint);
printf("ROM start address at %08lx\n", ROMBaseMac);
printf("Set ROM break point at %08lx\n", ROMBaseMac + ROMBreakpoint);
#else
uint16 *wp = (uint16 *)(ROMBaseHost + ROMBreakpoint); uint16 *wp = (uint16 *)(ROMBaseHost + ROMBreakpoint);
*wp = htons(M68K_EMUL_BREAK); *wp = htons(M68K_EMUL_BREAK);
#endif
} }
// Clear caches as we loaded and patched code // Clear caches as we loaded and patched code

@ -26,6 +26,7 @@
#include <ctype.h> #include <ctype.h>
#include <string> #include <string>
#include <map> #include <map>
#include <sstream>
#if defined(HAVE_READLINE_H) #if defined(HAVE_READLINE_H)
extern "C" { extern "C" {
@ -66,7 +67,7 @@ static uint8 *mem;
// Streams for input, output and error messages // Streams for input, output and error messages
FILE *monin, *monout, *monerr; FILE *monin, *monout, *monerr = NULL;
// Input line // Input line
static char *input; static char *input;
@ -153,7 +154,7 @@ void mon_add_command(const char *name, void (*func)(), const char *help_text)
void mon_error(const char *s) void mon_error(const char *s)
{ {
fprintf(monerr, "*** %s\n", s); fprintf(monerr == NULL? stdout : monerr, "*** %s\n", s);
} }
@ -1029,6 +1030,63 @@ void mon_change_dir()
} }
/*
* Add break point
*/
void mon_add_break_point(uintptr addr)
{
BREAK_POINT_SET::iterator it = disabled_break_points.find(addr);
// Save break point
if (it == disabled_break_points.end()) {
active_break_points.insert(addr);
} else {
disabled_break_points.erase(it);
active_break_points.insert(addr);
}
}
/*
* Load break point from file
*/
void mon_load_break_point(const char* file_path)
{
FILE *file;
if (!(file = fopen(file_path, "r"))) {
mon_error("Unable to create file");
return;
}
char line_buff[1024];
bool is_disabled_break_points = false;
if (fgets(line_buff, sizeof(line_buff), file) == NULL ||
strcmp(line_buff, STR_ACTIVE_BREAK_POINTS) != 0) {
mon_error("Invalid break point file format!");
fclose(file);
return;
}
while (fgets(line_buff, sizeof(line_buff), file) != NULL) {
if (strcmp(line_buff, STR_DISABLED_BREAK_POINTS) == 0) {
is_disabled_break_points = true;
continue;
}
uintptr address;
std::stringstream ss;
ss << std::hex << line_buff;
ss >> address;
if (is_disabled_break_points)
disabled_break_points.insert(address);
else
active_break_points.insert(address);
}
fclose(file);
}
/* /*
* Initialize mon * Initialize mon
*/ */

@ -33,6 +33,9 @@ void mon_init();
void mon_exit(); void mon_exit();
void mon(int argc, char **argv); void mon(int argc, char **argv);
// Break points prompt
const char STR_ACTIVE_BREAK_POINTS[] = "Active Break Points:\n";
const char STR_DISABLED_BREAK_POINTS[] = "Disabled Break Points:\n";
/* /*
* Definitions for adding commands to mon * Definitions for adding commands to mon
@ -104,5 +107,8 @@ extern void mon_write_word(uintptr adr, uint32 l);
// Check if break point is set // Check if break point is set
#define IS_BREAK_POINT(address) (active_break_points.find(address) != active_break_points.end()) #define IS_BREAK_POINT(address) (active_break_points.find(address) != active_break_points.end())
// Add break point
extern void mon_add_break_point(uintptr addr);
extern void mon_load_break_point(const char* file_path);
#endif #endif

@ -1,4 +1,4 @@
/* /*
* mon_cmd.cpp - cxmon standard commands * mon_cmd.cpp - cxmon standard commands
* *
* cxmon (C) 1997-2004 Christian Bauer, Marc Hellwig * cxmon (C) 1997-2004 Christian Bauer, Marc Hellwig
@ -22,7 +22,6 @@
#include <stdlib.h> #include <stdlib.h>
#include <assert.h> #include <assert.h>
#include <sstream>
#include "mon.h" #include "mon.h"
#include "mon_cmd.h" #include "mon_cmd.h"
@ -33,9 +32,6 @@
#endif #endif
static const char STR_ACTIVE_BREAK_POINTS[] = "Active Break Points:\n";
static const char STR_DISABLED_BREAK_POINTS[] = "Disabled Break Points:\n";
/* /*
* range_args = [expression] [[COMMA] expression] END * range_args = [expression] [[COMMA] expression] END
* *
@ -323,14 +319,7 @@ void break_point_add(void)
return; return;
} }
BREAK_POINT_SET::iterator it; mon_add_break_point(address);
// Save break point
if ((it = disabled_break_points.find(address)) == disabled_break_points.end())
active_break_points.insert(address);
else {
disabled_break_points.erase(it);
active_break_points.insert(address);
}
} }
@ -521,38 +510,8 @@ void break_point_load(void)
return; return;
} }
FILE *file; // load from file
if (!(file = fopen(mon_string, "r"))) { mon_load_break_point(mon_string);
mon_error("Unable to create file");
return;
}
char line_buff[1024];
bool is_disabled_break_points = false;
if (fgets(line_buff, sizeof(line_buff), file) == NULL ||
strcmp(line_buff, STR_ACTIVE_BREAK_POINTS) != 0) {
mon_error("Invalid break point file format!");
fclose(file);
return;
}
while (fgets(line_buff, sizeof(line_buff), file) != NULL) {
if (strcmp(line_buff, STR_DISABLED_BREAK_POINTS) == 0) {
is_disabled_break_points = true;
continue;
}
uintptr address;
std::stringstream ss;
ss << std::hex << line_buff;
ss >> address;
if (is_disabled_break_points)
disabled_break_points.insert(address);
else
active_break_points.insert(address);
}
fclose(file);
} }