mirror of
https://github.com/bminor/binutils-gdb.git
synced 2025-12-26 17:18:55 +00:00
* gdbarch.sh (get_longjmp_target): Add FRAME argument.
* gdbarch.c, gdbarch.h: Regenerate. * infrun.c (handle_inferior_event): Pass current frame to gdbarch_get_longjmp_target. * alpha-tdep.c (alpha_get_longjmp_target): Add FRAME argument. Read registers from FRAME instead of using read_register. Use get_frame_arch instead of current_gdbarch. * arm-tdep.c (arm_get_longjmp_target): Likewise. * i386-tdep.c (i386_get_longjmp_target): Likewise. * m68k-tdep.c (m68k_get_longjmp_target): Likewise. * mips-linux-tdep.c (mips_linux_get_longjmp_target): Likewise. (mips64_linux_get_longjmp_target): Likewise. * mipsnbsd-tdep.c (mipsnbsd_get_longjmp_target): Likewise.
This commit is contained in:
@@ -724,13 +724,13 @@ alpha_skip_prologue (CORE_ADDR pc)
|
||||
into the "pc". This routine returns true on success. */
|
||||
|
||||
static int
|
||||
alpha_get_longjmp_target (CORE_ADDR *pc)
|
||||
alpha_get_longjmp_target (struct frame_info *frame, CORE_ADDR *pc)
|
||||
{
|
||||
struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
|
||||
struct gdbarch_tdep *tdep = gdbarch_tdep (get_frame_arch (frame));
|
||||
CORE_ADDR jb_addr;
|
||||
gdb_byte raw_buffer[ALPHA_REGISTER_SIZE];
|
||||
|
||||
jb_addr = read_register (ALPHA_A0_REGNUM);
|
||||
jb_addr = get_frame_register_unsigned (frame, ALPHA_A0_REGNUM);
|
||||
|
||||
if (target_read_memory (jb_addr + (tdep->jb_pc * tdep->jb_elt_size),
|
||||
raw_buffer, tdep->jb_elt_size))
|
||||
|
||||
Reference in New Issue
Block a user