mirror of https://github.com/mgba-emu/mgba.git
Debugger: Add command to load external symbol file (fixes #2480)
This commit is contained in:
parent
492ba2478c
commit
8f133caec8
1
CHANGES
1
CHANGES
|
@ -51,6 +51,7 @@ Misc:
|
||||||
- Core: Suspend runloop when a core crashes
|
- Core: Suspend runloop when a core crashes
|
||||||
- Debugger: Save and restore CLI history
|
- Debugger: Save and restore CLI history
|
||||||
- Debugger: GDB now works while the game is paused
|
- Debugger: GDB now works while the game is paused
|
||||||
|
- Debugger: Add command to load external symbol file (fixes mgba.io/i/2480)
|
||||||
- GB MBC: Filter out MBC errors when cartridge is yanked (fixes mgba.io/i/2488)
|
- GB MBC: Filter out MBC errors when cartridge is yanked (fixes mgba.io/i/2488)
|
||||||
- GB Video: Add default SGB border
|
- GB Video: Add default SGB border
|
||||||
- GBA: Automatically skip BIOS if ROM has invalid logo
|
- GBA: Automatically skip BIOS if ROM has invalid logo
|
||||||
|
|
|
@ -8,15 +8,17 @@
|
||||||
#include <mgba/internal/debugger/symbols.h>
|
#include <mgba/internal/debugger/symbols.h>
|
||||||
|
|
||||||
#include <mgba/core/core.h>
|
#include <mgba/core/core.h>
|
||||||
#include <mgba/core/timing.h>
|
|
||||||
#include <mgba/core/version.h>
|
|
||||||
#include <mgba/internal/debugger/parser.h>
|
|
||||||
#include <mgba-util/string.h>
|
|
||||||
#include <mgba-util/vfs.h>
|
|
||||||
|
|
||||||
#ifdef ENABLE_SCRIPTING
|
#ifdef ENABLE_SCRIPTING
|
||||||
#include <mgba/core/scripting.h>
|
#include <mgba/core/scripting.h>
|
||||||
#endif
|
#endif
|
||||||
|
#include <mgba/core/timing.h>
|
||||||
|
#include <mgba/core/version.h>
|
||||||
|
#include <mgba/internal/debugger/parser.h>
|
||||||
|
#ifdef USE_ELF
|
||||||
|
#include <mgba-util/elf-read.h>
|
||||||
|
#endif
|
||||||
|
#include <mgba-util/string.h>
|
||||||
|
#include <mgba-util/vfs.h>
|
||||||
|
|
||||||
#if !defined(NDEBUG) && !defined(_WIN32)
|
#if !defined(NDEBUG) && !defined(_WIN32)
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
|
@ -74,6 +76,7 @@ static void _source(struct CLIDebugger*, struct CLIDebugVector*);
|
||||||
static void _backtrace(struct CLIDebugger*, struct CLIDebugVector*);
|
static void _backtrace(struct CLIDebugger*, struct CLIDebugVector*);
|
||||||
static void _finish(struct CLIDebugger*, struct CLIDebugVector*);
|
static void _finish(struct CLIDebugger*, struct CLIDebugVector*);
|
||||||
static void _setStackTraceMode(struct CLIDebugger*, struct CLIDebugVector*);
|
static void _setStackTraceMode(struct CLIDebugger*, struct CLIDebugVector*);
|
||||||
|
static void _loadSymbols(struct CLIDebugger*, struct CLIDebugVector*);
|
||||||
static void _setSymbol(struct CLIDebugger*, struct CLIDebugVector*);
|
static void _setSymbol(struct CLIDebugger*, struct CLIDebugVector*);
|
||||||
static void _findSymbol(struct CLIDebugger*, struct CLIDebugVector*);
|
static void _findSymbol(struct CLIDebugger*, struct CLIDebugVector*);
|
||||||
|
|
||||||
|
@ -101,6 +104,7 @@ static struct CLIDebuggerCommandSummary _debuggerCommands[] = {
|
||||||
{ "stack", _setStackTraceMode, "S", "Change the stack tracing mode" },
|
{ "stack", _setStackTraceMode, "S", "Change the stack tracing mode" },
|
||||||
{ "status", _printStatus, "", "Print the current status" },
|
{ "status", _printStatus, "", "Print the current status" },
|
||||||
{ "symbol", _findSymbol, "I", "Find the symbol name for an address" },
|
{ "symbol", _findSymbol, "I", "Find the symbol name for an address" },
|
||||||
|
{ "load-symbols", _loadSymbols, "S", "Load symbols from an external file" },
|
||||||
{ "trace", _trace, "Is", "Trace a number of instructions" },
|
{ "trace", _trace, "Is", "Trace a number of instructions" },
|
||||||
{ "w/1", _writeByte, "II", "Write a byte at a specified offset" },
|
{ "w/1", _writeByte, "II", "Write a byte at a specified offset" },
|
||||||
{ "w/2", _writeHalfword, "II", "Write a halfword at a specified offset" },
|
{ "w/2", _writeHalfword, "II", "Write a halfword at a specified offset" },
|
||||||
|
@ -133,6 +137,7 @@ static struct CLIDebuggerCommandAlias _debuggerCommandAliases[] = {
|
||||||
{ "h", "help" },
|
{ "h", "help" },
|
||||||
{ "i", "status" },
|
{ "i", "status" },
|
||||||
{ "info", "status" },
|
{ "info", "status" },
|
||||||
|
{ "loadsyms", "load-symbols" },
|
||||||
{ "lb", "listb" },
|
{ "lb", "listb" },
|
||||||
{ "lw", "listw" },
|
{ "lw", "listw" },
|
||||||
{ "n", "next" },
|
{ "n", "next" },
|
||||||
|
@ -1291,6 +1296,40 @@ static void _setStackTraceMode(struct CLIDebugger* debugger, struct CLIDebugVect
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void _loadSymbols(struct CLIDebugger* debugger, struct CLIDebugVector* dv) {
|
||||||
|
struct mDebuggerSymbols* symbolTable = debugger->d.core->symbolTable;
|
||||||
|
if (!symbolTable) {
|
||||||
|
debugger->backend->printf(debugger->backend, "No symbol table available.\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (!dv || dv->next) {
|
||||||
|
debugger->backend->printf(debugger->backend, "%s\n", ERROR_MISSING_ARGS);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (dv->type != CLIDV_CHAR_TYPE) {
|
||||||
|
debugger->backend->printf(debugger->backend, "%s\n", ERROR_INVALID_ARGS);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
struct VFile* vf = VFileOpen(dv->charValue, O_RDONLY);
|
||||||
|
if (!vf) {
|
||||||
|
debugger->backend->printf(debugger->backend, "%s\n", "Could not open symbol file");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#ifdef USE_ELF
|
||||||
|
struct ELF* elf = ELFOpen(vf);
|
||||||
|
if (elf) {
|
||||||
|
#ifdef USE_DEBUGGERS
|
||||||
|
mCoreLoadELFSymbols(symbolTable, elf);
|
||||||
|
#endif
|
||||||
|
ELFClose(elf);
|
||||||
|
} else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
mDebuggerLoadARMIPSSymbols(symbolTable, vf);
|
||||||
|
}
|
||||||
|
vf->close(vf);
|
||||||
|
}
|
||||||
|
|
||||||
static void _setSymbol(struct CLIDebugger* debugger, struct CLIDebugVector* dv) {
|
static void _setSymbol(struct CLIDebugger* debugger, struct CLIDebugVector* dv) {
|
||||||
struct mDebuggerSymbols* symbolTable = debugger->d.core->symbolTable;
|
struct mDebuggerSymbols* symbolTable = debugger->d.core->symbolTable;
|
||||||
if (!symbolTable) {
|
if (!symbolTable) {
|
||||||
|
|
Loading…
Reference in New Issue