[Ltrace-devel] [PATCH 2/4] Fix insertion of breakpoints on Thumb code.
Zachary T Welch
zwelch at codesourcery.com
Fri Oct 8 18:47:49 UTC 2010
When a program has been built in Thumb mode, global symbols will
have their low bit set. Ensure that breakpoints are set at the
correct address and using Thumb instructions.
Signed-off-by: Zachary T Welch <zwelch at codesourcery.com>
---
ChangeLog | 4 ++++
breakpoints.c | 7 ++++++-
2 files changed, 10 insertions(+), 1 deletions(-)
diff --git a/ChangeLog b/ChangeLog
index 0501982..d93acc2 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+2010-10-07 Zach Welch <zwelch at codesourcery.com>
+
+ * Improve breakpoint insertion to work with Thumb procedures.
+
2010-09-30 Zach Welch <zwelch at codesourcery.com>
* Improve ARM syscall_p to handle Thumb-2 syscalls.
diff --git a/breakpoints.c b/breakpoints.c
index ba3b060..ad68f0d 100644
--- a/breakpoints.c
+++ b/breakpoints.c
@@ -22,6 +22,11 @@ void
insert_breakpoint(Process *proc, void *addr,
struct library_symbol *libsym) {
Breakpoint *sbp;
+#ifdef __arm__
+ int thumb_mode = (int)addr & 1;
+ if (thumb_mode)
+ addr = (void *)((int)addr & ~1);
+#endif
debug(DEBUG_FUNCTION, "insert_breakpoint(pid=%d, addr=%p, symbol=%s)", proc->pid, addr, libsym ? libsym->name : "NULL");
debug(1, "symbol=%s, addr=%p", libsym?libsym->name:"(nil)", addr);
@@ -43,7 +48,7 @@ insert_breakpoint(Process *proc, void *addr,
sbp->libsym = libsym;
}
#ifdef __arm__
- sbp->thumb_mode = proc->thumb_mode;
+ sbp->thumb_mode = thumb_mode | proc->thumb_mode;
proc->thumb_mode = 0;
#endif
sbp->enabled++;
--
1.7.2.2
More information about the Ltrace-devel
mailing list