diff options
author | Mark Kettenis <kettenis@gnu.org> | 2004-07-23 13:43:36 +0000 |
---|---|---|
committer | Mark Kettenis <kettenis@gnu.org> | 2004-07-23 13:43:36 +0000 |
commit | 24f033e800a318cbfa00f79a06e037c98fe5883f (patch) | |
tree | 70f69df685670ab51af26831a7357d9205757aad /gdb | |
parent | 90f3cecd6ae6ffb2adb87e4d46a4317e0a7bcf10 (diff) | |
download | gdb-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/ChangeLog | 3 | ||||
-rw-r--r-- | gdb/sparc64obsd-tdep.c | 19 |
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; |