mirror of https://github.com/mgba-emu/mgba.git
ARM Debugger: Clear low bit on breakpoint addresses (fixes #1764)
This commit is contained in:
parent
ff4406fab0
commit
ff1033b801
1
CHANGES
1
CHANGES
|
@ -26,6 +26,7 @@ Emulation fixes:
|
||||||
- GBA Video: Fix disabling OBJWIN in GL renderer (fixes mgba.io/i/1759)
|
- GBA Video: Fix disabling OBJWIN in GL renderer (fixes mgba.io/i/1759)
|
||||||
Other fixes:
|
Other fixes:
|
||||||
- All: Improve export headers (fixes mgba.io/i/1738)
|
- All: Improve export headers (fixes mgba.io/i/1738)
|
||||||
|
- ARM Debugger: Clear low bit on breakpoint addresses (fixes mgba.io/i/1764)
|
||||||
- CMake: Always use devkitPro toolchain when applicable (fixes mgba.io/i/1755)
|
- CMake: Always use devkitPro toolchain when applicable (fixes mgba.io/i/1755)
|
||||||
- Core: Ensure ELF regions can be written before trying
|
- Core: Ensure ELF regions can be written before trying
|
||||||
- Core: Fix ELF loading regression (fixes mgba.io/i/1669)
|
- Core: Fix ELF loading regression (fixes mgba.io/i/1669)
|
||||||
|
|
|
@ -171,7 +171,7 @@ ssize_t ARMDebuggerSetSoftwareBreakpoint(struct mDebuggerPlatform* d, uint32_t a
|
||||||
ssize_t id = debugger->nextId;
|
ssize_t id = debugger->nextId;
|
||||||
++debugger->nextId;
|
++debugger->nextId;
|
||||||
breakpoint->d.id = id;
|
breakpoint->d.id = id;
|
||||||
breakpoint->d.address = address;
|
breakpoint->d.address = address & ~1; // Clear Thumb bit since it's not part of a valid address
|
||||||
breakpoint->d.segment = -1;
|
breakpoint->d.segment = -1;
|
||||||
breakpoint->d.condition = NULL;
|
breakpoint->d.condition = NULL;
|
||||||
breakpoint->d.type = BREAKPOINT_SOFTWARE;
|
breakpoint->d.type = BREAKPOINT_SOFTWARE;
|
||||||
|
@ -187,6 +187,7 @@ static ssize_t ARMDebuggerSetBreakpoint(struct mDebuggerPlatform* d, const struc
|
||||||
ssize_t id = debugger->nextId;
|
ssize_t id = debugger->nextId;
|
||||||
++debugger->nextId;
|
++debugger->nextId;
|
||||||
breakpoint->d = *info;
|
breakpoint->d = *info;
|
||||||
|
breakpoint->d.address &= ~1; // Clear Thumb bit since it's not part of a valid address
|
||||||
breakpoint->d.id = id;
|
breakpoint->d.id = id;
|
||||||
if (info->type == BREAKPOINT_SOFTWARE) {
|
if (info->type == BREAKPOINT_SOFTWARE) {
|
||||||
// TODO
|
// TODO
|
||||||
|
|
Loading…
Reference in New Issue