aboutsummaryrefslogtreecommitdiff
path: root/gdb
diff options
context:
space:
mode:
authorMark Kettenis <kettenis@gnu.org>2004-07-23 13:43:36 +0000
committerMark Kettenis <kettenis@gnu.org>2004-07-23 13:43:36 +0000
commit24f033e800a318cbfa00f79a06e037c98fe5883f (patch)
tree70f69df685670ab51af26831a7357d9205757aad /gdb
parent90f3cecd6ae6ffb2adb87e4d46a4317e0a7bcf10 (diff)
downloadgdb-24f033e800a318cbfa00f79a06e037c98fe5883f.zip
gdb-24f033e800a318cbfa00f79a06e037c98fe5883f.tar.gz
gdb-24f033e800a318cbfa00f79a06e037c98fe5883f.tar.bz2
* sparc64obsd-tdep.c (sparc64obsd_pc_in_sigtramp): Adjust for
changed signal trampoline in OpenBSD 3.5-current.
Diffstat (limited to 'gdb')
-rw-r--r--gdb/ChangeLog3
-rw-r--r--gdb/sparc64obsd-tdep.c19
2 files changed, 19 insertions, 3 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index d434c56..65eaef0 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,5 +1,8 @@
2004-07-23 Mark Kettenis <kettenis@gnu.org>
+ * sparc64obsd-tdep.c (sparc64obsd_pc_in_sigtramp): Adjust for
+ changed signal trampoline in OpenBSD 3.5-current.
+
* sparc64nbsd-nat.c: Include "regcache.h", <sys/types.h>,
<machine/pcb.h> and "bsd-kvm.h".
(sparc64nbsd_supply_pcb): New function.
diff --git a/gdb/sparc64obsd-tdep.c b/gdb/sparc64obsd-tdep.c
index b74679c..8ad88b5 100644
--- a/gdb/sparc64obsd-tdep.c
+++ b/gdb/sparc64obsd-tdep.c
@@ -83,17 +83,30 @@ sparc64obsd_pc_in_sigtramp (CORE_ADDR pc, char *name)
{
CORE_ADDR start_pc = (pc & ~(sparc64obsd_page_size - 1));
unsigned long insn;
+ int offset = 0;
if (name)
return 0;
+ retry:
/* Check for "restore %g0, SYS_sigreturn, %g1". */
- insn = sparc_fetch_instruction (start_pc + 0xe8);
+ insn = sparc_fetch_instruction (start_pc + offset + 0xec);
if (insn != 0x83e82067)
- return 0;
+ {
+ if (offset == 0)
+ {
+ /* In OpenBSD 3.5 and earlier releases, the code
+ implementing the sigreturn system call was at a different
+ offset within the signal trampoline. Try again. */
+ offset = -4;
+ goto retry;
+ }
+
+ return 0;
+ }
/* Check for "t ST_SYSCALL". */
- insn = sparc_fetch_instruction (start_pc + 0xf0);
+ insn = sparc_fetch_instruction (start_pc + offset + 0xf4);
if (insn != 0x91d02000)
return 0;