]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
* gdb/m68k-tdep.c (m68k_dwarf_reg_to_regnum): New.
authorNathan Sidwell <nathan@codesourcery.com>
Mon, 5 Jun 2006 15:00:39 +0000 (15:00 +0000)
committerNathan Sidwell <nathan@codesourcery.com>
Mon, 5 Jun 2006 15:00:39 +0000 (15:00 +0000)
(m68k_gdbarch_init): Set it for dwarf & dwarf2 reg number
conversion. Use M68K_NUM_REGS for number of regs.

ChangeLog.csl
gdb/m68k-tdep.c

index 95f6f57ec9e11bda36664f78287b5f27d5dd11c8..8855da125a04f7b834462f40d2c9b2cf6e4b0ab0 100644 (file)
@@ -1,5 +1,9 @@
 2006-06-05  Nathan Sidwell  <nathan@codesourcery.com>
 
+       * 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.
index bfec932be79b933673220fffeee6359e46151d7d..4aeb70da49923165fa0376b342a65664c4970cb2 100644 (file)
@@ -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;
+}
+
 \f
 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);