X-Git-Url: http://drtracing.org/?a=blobdiff_plain;f=gdb%2Falpha-osf1-tdep.c;h=f3bddaa8810cf48ccbb98f1a233cafb4e82b2460;hb=ffda88b4801e1ea163e7eb0962008c60f353c229;hp=4dcc43b32a36b1ad199e536b4ebd0291f04232e7;hpb=a9762ec78a53fbe9209fe1654db42df0cd328d50;p=deliverable%2Fbinutils-gdb.git diff --git a/gdb/alpha-osf1-tdep.c b/gdb/alpha-osf1-tdep.c index 4dcc43b32a..f3bddaa881 100644 --- a/gdb/alpha-osf1-tdep.c +++ b/gdb/alpha-osf1-tdep.c @@ -1,5 +1,5 @@ /* Target-dependent code for OSF/1 on Alpha. - Copyright (C) 2002, 2003, 2007 Free Software Foundation, Inc. + Copyright (C) 2002-2003, 2007-2012 Free Software Foundation, Inc. This file is part of GDB. @@ -27,17 +27,24 @@ #include "alpha-tdep.h" static int -alpha_osf1_pc_in_sigtramp (CORE_ADDR pc, char *func_name) +alpha_osf1_pc_in_sigtramp (struct gdbarch *gdbarch, + CORE_ADDR pc, const char *func_name) { return (func_name != NULL && strcmp ("__sigtramp", func_name) == 0); } static CORE_ADDR -alpha_osf1_sigcontext_addr (struct frame_info *next_frame) +alpha_osf1_sigcontext_addr (struct frame_info *this_frame) { - const struct frame_id next_id = get_frame_id (next_frame); + struct gdbarch *gdbarch = get_frame_arch (this_frame); + enum bfd_endian byte_order = gdbarch_byte_order (gdbarch); + struct frame_info *next_frame = get_next_frame (this_frame); + struct frame_id next_id = null_frame_id; + + if (next_frame != NULL) + next_id = get_frame_id (next_frame); - return (read_memory_integer (next_id.stack_addr, 8)); + return (read_memory_integer (next_id.stack_addr, 8, byte_order)); } static void @@ -50,8 +57,8 @@ alpha_osf1_init_abi (struct gdbarch_info info, alpha_mdebug_init_abi (info, gdbarch); /* The next/step support via procfs on OSF1 is broken when running - on multi-processor machines. We need to use software single stepping - instead. */ + on multi-processor machines. We need to use software single + stepping instead. */ set_gdbarch_software_single_step (gdbarch, alpha_software_single_step); tdep->sigcontext_addr = alpha_osf1_sigcontext_addr; @@ -61,6 +68,9 @@ alpha_osf1_init_abi (struct gdbarch_info info, tdep->jb_elt_size = 8; } +/* Provide a prototype to silence -Wmissing-prototypes. */ +extern initialize_file_ftype _initialize_alpha_osf1_tdep; + void _initialize_alpha_osf1_tdep (void) {