diff options
author | Mark Kettenis <kettenis@gnu.org> | 2006-07-09 22:01:59 +0000 |
---|---|---|
committer | Mark Kettenis <kettenis@gnu.org> | 2006-07-09 22:01:59 +0000 |
commit | b0ca85736544b15d99386b9da5d39586a4c5eb97 (patch) | |
tree | cbf14efb0f5f388c9ac8948fff895361602486ba | |
parent | 3b03cc436125ee5a53661fa21416f0d63ab042db (diff) | |
download | gdb-b0ca85736544b15d99386b9da5d39586a4c5eb97.zip gdb-b0ca85736544b15d99386b9da5d39586a4c5eb97.tar.gz gdb-b0ca85736544b15d99386b9da5d39586a4c5eb97.tar.bz2 |
* alphabsd-tdep.h (alphanbsd_regset_from_core_section): New
prototype.
* alphanbsd-tdep.c (alphanbsd_regset_from_core_section): Handle
a.out-style core file format here. Make global.
(alphanbsd_regset_from_core_section): Remove.
(alphanbsd_sigtramp_offset): Make static.
(alphanbsd_aout_init_abi): Remove.
(alphanbsd_core_osabi_sniffer): Return GDB_OSABI_NETBSD_ELF for
a.out style core files.
(_initialize_alphanbsd_tdep): Do not register a handler for
GDB_OSABI_NETBSD_AOUT.
-rw-r--r-- | gdb/ChangeLog | 12 | ||||
-rw-r--r-- | gdb/alphabsd-tdep.h | 9 | ||||
-rw-r--r-- | gdb/alphanbsd-tdep.c | 39 |
3 files changed, 32 insertions, 28 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index c666534..a9aab62 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,5 +1,17 @@ 2006-07-09 Mark Kettenis <kettenis@gnu.org> + * alphabsd-tdep.h (alphanbsd_regset_from_core_section): New + prototype. + * alphanbsd-tdep.c (alphanbsd_regset_from_core_section): Handle + a.out-style core file format here. Make global. + (alphanbsd_regset_from_core_section): Remove. + (alphanbsd_sigtramp_offset): Make static. + (alphanbsd_aout_init_abi): Remove. + (alphanbsd_core_osabi_sniffer): Return GDB_OSABI_NETBSD_ELF for + a.out style core files. + (_initialize_alphanbsd_tdep): Do not register a handler for + GDB_OSABI_NETBSD_AOUT. + * alphabsd-tdep.h: Tweak comments. (SIZEOF_STRUCT_REG, SIZEOF_STRUCT_FPREG): Remove. * alphanbsd-tdep.c: Reorder includes. Include "regset.h". diff --git a/gdb/alphabsd-tdep.h b/gdb/alphabsd-tdep.h index e434895..9d74945 100644 --- a/gdb/alphabsd-tdep.h +++ b/gdb/alphabsd-tdep.h @@ -27,5 +27,14 @@ void alphabsd_fill_reg (char *, int); void alphabsd_supply_fpreg (char *, int); void alphabsd_fill_fpreg (char *, int); + + +/* Functions exported from alphanbsd-tdep.c. */ + +/* Return the appropriate register set for the core section identified + by SECT_NAME and SECT_SIZE. */ +extern const struct regset * + alphanbsd_regset_from_core_section (struct gdbarch *gdbarch, + const char *sect_name, size_t len); #endif /* alphabsd-tdep.h */ diff --git a/gdb/alphanbsd-tdep.c b/gdb/alphanbsd-tdep.c index ca1ecff..44f1145 100644 --- a/gdb/alphanbsd-tdep.c +++ b/gdb/alphanbsd-tdep.c @@ -163,29 +163,23 @@ static struct regset alphanbsd_aout_gregset = /* Return the appropriate register set for the core section identified by SECT_NAME and SECT_SIZE. */ -static const struct regset * +const struct regset * alphanbsd_regset_from_core_section (struct gdbarch *gdbarch, const char *sect_name, size_t sect_size) { if (strcmp (sect_name, ".reg") == 0 && sect_size >= ALPHANBSD_SIZEOF_GREGS) - return &alphanbsd_gregset; + { + if (sect_size >= ALPHANBSD_SIZEOF_GREGS + ALPHANBSD_SIZEOF_FPREGS) + return &alphanbsd_aout_gregset; + else + return &alphanbsd_gregset; + } if (strcmp (sect_name, ".reg2") == 0 && sect_size >= ALPHANBSD_SIZEOF_FPREGS) return &alphanbsd_fpregset; return NULL; } - -static const struct regset * -alphanbsd_aout_regset_from_core_section (struct gdbarch *gdbarch, - const char *sect_name, - size_t sect_size) -{ - if (strcmp (sect_name, ".reg") == 0 && sect_size >= ALPHANBSD_SIZEOF_GREGS) - return &alphanbsd_aout_gregset; - - return NULL; -} /* Signal trampolines. */ @@ -216,7 +210,7 @@ static const unsigned char sigtramp_retcode[] = #define RETCODE_NWORDS 4 #define RETCODE_SIZE (RETCODE_NWORDS * 4) -LONGEST +static LONGEST alphanbsd_sigtramp_offset (CORE_ADDR pc) { unsigned char ret[RETCODE_SIZE], w[4]; @@ -261,6 +255,7 @@ alphanbsd_sigcontext_addr (struct frame_info *frame) out which trampoline frame type we have. */ return get_frame_base (frame); } + static void alphanbsd_init_abi (struct gdbarch_info info, @@ -292,23 +287,13 @@ alphanbsd_init_abi (struct gdbarch_info info, set_gdbarch_regset_from_core_section (gdbarch, alphanbsd_regset_from_core_section); } - -static void -alphanbsd_aout_init_abi (struct gdbarch_info info, - struct gdbarch *gdbarch) -{ - alphanbsd_init_abi(info, gdbarch); - - set_gdbarch_regset_from_core_section - (gdbarch, alphanbsd_aout_regset_from_core_section); -} static enum gdb_osabi alphanbsd_core_osabi_sniffer (bfd *abfd) { if (strcmp (bfd_get_target (abfd), "netbsd-core") == 0) - return GDB_OSABI_NETBSD_AOUT; + return GDB_OSABI_NETBSD_ELF; return GDB_OSABI_UNKNOWN; } @@ -326,8 +311,6 @@ _initialize_alphanbsd_tdep (void) gdbarch_register_osabi (bfd_arch_alpha, 0, GDB_OSABI_NETBSD_ELF, alphanbsd_init_abi); - gdbarch_register_osabi (bfd_arch_alpha, 0, GDB_OSABI_NETBSD_AOUT, - alphanbsd_aout_init_abi); gdbarch_register_osabi (bfd_arch_alpha, 0, GDB_OSABI_OPENBSD_ELF, - alphanbsd_aout_init_abi); + alphanbsd_init_abi); } |