* sparc64obsd-tdep.c (sparc64obsd_sigreturn_offset): New variable.
(sparc64obsd_pc_in_sigtramp): Reorganize to avoid goto.
This commit is contained in:
parent
c724d49b86
commit
dc8566929c
2 changed files with 23 additions and 21 deletions
|
@ -1,3 +1,8 @@
|
|||
2004-07-31 Mark Kettenis <kettenis@gnu.org>
|
||||
|
||||
* sparc64obsd-tdep.c (sparc64obsd_sigreturn_offset): New variable.
|
||||
(sparc64obsd_pc_in_sigtramp): Reorganize to avoid goto.
|
||||
|
||||
2004-07-30 Andrew Cagney <cagney@gnu.org>
|
||||
|
||||
* GDB 6.2 released from gdb_6_2-branch.
|
||||
|
|
|
@ -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;
|
||||
}
|
||||
/* Check for "restore %g0, SYS_sigreturn, %g1". */
|
||||
insn = sparc_fetch_instruction (start_pc + *offset);
|
||||
if (insn != 0x83e82067)
|
||||
continue;
|
||||
|
||||
return 0;
|
||||
}
|
||||
/* Check for "t ST_SYSCALL". */
|
||||
insn = sparc_fetch_instruction (start_pc + *offset + 8);
|
||||
if (insn != 0x91d02000)
|
||||
continue;
|
||||
|
||||
/* Check for "t ST_SYSCALL". */
|
||||
insn = sparc_fetch_instruction (start_pc + offset + 0xf4);
|
||||
if (insn != 0x91d02000)
|
||||
return 0;
|
||||
return 1;
|
||||
}
|
||||
|
||||
return 1;
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct sparc_frame_cache *
|
||||
|
|
Loading…
Reference in a new issue