From: Nathan Sidwell Date: Mon, 5 Jun 2006 15:00:39 +0000 (+0000) Subject: * gdb/m68k-tdep.c (m68k_dwarf_reg_to_regnum): New. X-Git-Tag: gdb-csl-arm-2006q1-6~6 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=2b521eaaa3fecf7ea8c1159941302b6052f9e154;p=thirdparty%2Fbinutils-gdb.git * gdb/m68k-tdep.c (m68k_dwarf_reg_to_regnum): New. (m68k_gdbarch_init): Set it for dwarf & dwarf2 reg number conversion. Use M68K_NUM_REGS for number of regs. --- diff --git a/ChangeLog.csl b/ChangeLog.csl index 95f6f57ec9e..8855da125a0 100644 --- a/ChangeLog.csl +++ b/ChangeLog.csl @@ -1,5 +1,9 @@ 2006-06-05 Nathan Sidwell + * gdb/m68k-tdep.c (m68k_dwarf_reg_to_regnum): New. + (m68k_gdbarch_init): Set it for dwarf & dwarf2 reg number + conversion. Use M68K_NUM_REGS for number of regs. + * gdb/configure.tgt (gdb_osabi): uclinux is like linux. * gdb/m68k-tdep.c (m68k_svr4_extract_return_value): Return value is never in %a0. diff --git a/gdb/m68k-tdep.c b/gdb/m68k-tdep.c index bfec932be79..4aeb70da499 100644 --- a/gdb/m68k-tdep.c +++ b/gdb/m68k-tdep.c @@ -555,6 +555,28 @@ m68k_push_dummy_call (struct gdbarch *gdbarch, struct value *function, frame's CFA. */ return sp + 8; } + +/* Convert a dwarf or dwarf2 regnumber to a GDB regnum */ + +static int +m68k_dwarf_reg_to_regnum (int num) +{ + if (num < 8) + /* d0..7 */ + return (num - 0) + M68K_D0_REGNUM; + else if (num < 16) + /* a0..7 */ + return (num - 8) + M68K_A0_REGNUM; + else if (num < 24) + /* fp0..7 */ + return (num - 16) + M68K_FP0_REGNUM; + else if (num == 25) + /* pc */ + return M68K_PC_REGNUM; + else + return NUM_REGS + NUM_PSEUDO_REGS; +} + struct m68k_frame_cache { @@ -1240,10 +1262,12 @@ m68k_gdbarch_init (struct gdbarch_info info, struct gdbarch_list *arches) set_gdbarch_decr_pc_after_break (gdbarch, 2); set_gdbarch_frame_args_skip (gdbarch, 8); + set_gdbarch_dwarf_reg_to_regnum (gdbarch, m68k_dwarf_reg_to_regnum); + set_gdbarch_dwarf2_reg_to_regnum (gdbarch, m68k_dwarf_reg_to_regnum); set_gdbarch_register_type (gdbarch, m68k_register_type); set_gdbarch_register_name (gdbarch, m68k_register_name); - set_gdbarch_num_regs (gdbarch, 29); + set_gdbarch_num_regs (gdbarch, M68K_NUM_REGS); set_gdbarch_register_bytes_ok (gdbarch, m68k_register_bytes_ok); set_gdbarch_sp_regnum (gdbarch, M68K_SP_REGNUM); set_gdbarch_pc_regnum (gdbarch, M68K_PC_REGNUM);