From: Mark Kettenis Date: Fri, 30 Jul 2004 22:45:52 +0000 (+0000) Subject: * sparc64obsd-tdep.c (sparc64obsd_sigreturn_offset): New variable. X-Git-Tag: csl-arm-2004-q3~710 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=dc8566929cf7298314e47fbda9e8a6592b73c18a;p=thirdparty%2Fbinutils-gdb.git * sparc64obsd-tdep.c (sparc64obsd_sigreturn_offset): New variable. (sparc64obsd_pc_in_sigtramp): Reorganize to avoid goto. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 9cfaf44ce44..732224fb358 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +2004-07-31 Mark Kettenis + + * sparc64obsd-tdep.c (sparc64obsd_sigreturn_offset): New variable. + (sparc64obsd_pc_in_sigtramp): Reorganize to avoid goto. + 2004-07-30 Andrew Cagney * GDB 6.2 released from gdb_6_2-branch. diff --git a/gdb/sparc64obsd-tdep.c b/gdb/sparc64obsd-tdep.c index 8ad88b556aa..bb6626deebc 100644 --- a/gdb/sparc64obsd-tdep.c +++ b/gdb/sparc64obsd-tdep.c @@ -74,43 +74,40 @@ sparc64obsd_supply_gregset (const struct regset *regset, The signal trampoline will be mapped at an address that is page aligned. We recognize the signal trampoline by the looking for the - sigreturn system call. */ + sigreturn system call. The offset where we can find the code that + makes this system call varies from release to release. For OpenBSD + 3.6 and later releases we can find the code at offset 0xec. For + OpenBSD 3.5 and earlier releases, we find it at offset 0xe8. */ static const int sparc64obsd_page_size = 8192; +static const int sparc64obsd_sigreturn_offset[] = { 0xec, 0xe8, -1 }; static int sparc64obsd_pc_in_sigtramp (CORE_ADDR pc, char *name) { CORE_ADDR start_pc = (pc & ~(sparc64obsd_page_size - 1)); unsigned long insn; - int offset = 0; + const int *offset; if (name) return 0; - retry: - /* Check for "restore %g0, SYS_sigreturn, %g1". */ - insn = sparc_fetch_instruction (start_pc + offset + 0xec); - if (insn != 0x83e82067) + for (offset = sparc64obsd_sigreturn_offset; *offset != -1; offset++) { - 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 "restore %g0, SYS_sigreturn, %g1". */ + insn = sparc_fetch_instruction (start_pc + *offset); + if (insn != 0x83e82067) + continue; - /* Check for "t ST_SYSCALL". */ - insn = sparc_fetch_instruction (start_pc + offset + 0xf4); - if (insn != 0x91d02000) - return 0; + /* Check for "t ST_SYSCALL". */ + insn = sparc_fetch_instruction (start_pc + *offset + 8); + if (insn != 0x91d02000) + continue; + + return 1; + } - return 1; + return 0; } static struct sparc_frame_cache *