This is the mail archive of the gdb-patches@sources.redhat.com mailing list for the GDB project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]

[patch] Flick mn10300 multi-arch switch.


FYI,

The attatched patch changes the mn10300 to a multi-arch target.  Much
work still to go tho.

	Andrew
2000-08-10  Andrew Cagney  <cagney@ops1.cygnus.com>

	* config/mn10300/tm-mn10300.h, mn10300-tdep.c
 	(mn10300_push_arguments): Fix function signature to match gdbarch
 	vector.
	* config/mn10300/tm-mn10300.h (REGISTER_NAME): Delete.
 	* mn10300-tdep.c (struct gdbarch_tdep): Define.
 	(mn10300_generic_register_names, am33_register_names): Convert to
 	functions.
 	(set_machine_hook): Delete.
 	(register_name): New function.
 	(mn10300_register_name): Delete.
 	(mn10300_dump_tdep, mn10300_gdbarch_init): New functions.
 	(_initialize_mn10300_tdep): Call register_gdbarch_init instead of
 	specify_exec_file_hook.
 	(AM33_MODE): Define.
 	(set_movm_offsets): Update.
 	
Index: mn10300-tdep.c
===================================================================
RCS file: /cvs/src/src/gdb/mn10300-tdep.c,v
retrieving revision 1.3
diff -p -r1.3 mn10300-tdep.c
*** mn10300-tdep.c	2000/07/30 01:48:26	1.3
--- mn10300-tdep.c	2000/08/11 07:51:25
***************
*** 1,5 ****
  /* Target-dependent code for the Matsushita MN10300 for GDB, the GNU debugger.
!    Copyright 1996, 1997, 1998 Free Software Foundation, Inc.
  
     This file is part of GDB.
  
--- 1,5 ----
  /* Target-dependent code for the Matsushita MN10300 for GDB, the GNU debugger.
!    Copyright 1996, 1997, 1998, 2000 Free Software Foundation, Inc.
  
     This file is part of GDB.
  
*************** extern void _initialize_mn10300_tdep (vo
*** 33,38 ****
--- 33,45 ----
  static CORE_ADDR mn10300_analyze_prologue (struct frame_info *fi,
  					   CORE_ADDR pc);
  
+ /* mn10300 private data */
+ struct gdbarch_tdep
+ {
+   int am33_mode;
+ #define AM33_MODE (gdbarch_tdep (current_gdbarch)->am33_mode)
+ };
+ 
  /* Additional info used by the frame */
  
  struct frame_extra_info
*************** struct frame_extra_info
*** 42,68 ****
    };
  
  
! static char *mn10300_generic_register_names[] =
! {"d0", "d1", "d2", "d3", "a0", "a1", "a2", "a3",
!  "sp", "pc", "mdr", "psw", "lir", "lar", "", "",
!  "", "", "", "", "", "", "", "",
!  "", "", "", "", "", "", "", "fp"};
! 
! static char **mn10300_register_names = mn10300_generic_register_names;
! static char *am33_register_names[] =
! {
!   "d0", "d1", "d2", "d3", "a0", "a1", "a2", "a3",
!   "sp", "pc", "mdr", "psw", "lir", "lar", "",
!   "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
!   "ssp", "msp", "usp", "mcrh", "mcrl", "mcvf", "", "", ""};
! static int am33_mode;
  
! char *
! mn10300_register_name (int i)
  {
!   return mn10300_register_names[i];
  }
  
  CORE_ADDR
  mn10300_saved_pc_after_call (struct frame_info *fi)
  {
--- 49,88 ----
    };
  
  
! static char *
! register_name (int reg, char **regs, long sizeof_regs)
! {
!   if (reg < 0 || reg >= sizeof_regs / sizeof (regs[0]))
!     return NULL;
!   else
!     return regs[reg];
! }
  
! static char *
! mn10300_generic_register_name (int reg)
  {
!   static char *regs[] =
!   { "d0", "d1", "d2", "d3", "a0", "a1", "a2", "a3",
!     "sp", "pc", "mdr", "psw", "lir", "lar", "", "",
!     "", "", "", "", "", "", "", "",
!     "", "", "", "", "", "", "", "fp"
!   };
!   return register_name (reg, regs, sizeof regs);
  }
  
+ 
+ static char *
+ am33_register_name (int reg)
+ {
+   static char *regs[] =
+   { "d0", "d1", "d2", "d3", "a0", "a1", "a2", "a3",
+     "sp", "pc", "mdr", "psw", "lir", "lar", "",
+     "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
+     "ssp", "msp", "usp", "mcrh", "mcrl", "mcvf", "", "", ""
+   };
+   return register_name (reg, regs, sizeof regs);
+ }
+   
  CORE_ADDR
  mn10300_saved_pc_after_call (struct frame_info *fi)
  {
*************** set_movm_offsets (struct frame_info *fi,
*** 194,200 ****
        fi->saved_regs[D2_REGNUM] = fi->frame + offset;
        offset += 4;
      }
!   if (am33_mode && movm_args & 0x02)
      {
        fi->saved_regs[E0_REGNUM + 5] = fi->frame + offset;
        fi->saved_regs[E0_REGNUM + 4] = fi->frame + offset + 4;
--- 214,220 ----
        fi->saved_regs[D2_REGNUM] = fi->frame + offset;
        offset += 4;
      }
!   if (AM33_MODE && movm_args & 0x02)
      {
        fi->saved_regs[E0_REGNUM + 5] = fi->frame + offset;
        fi->saved_regs[E0_REGNUM + 4] = fi->frame + offset + 4;
*************** mn10300_frame_chain (struct frame_info *
*** 543,549 ****
        adjust += (fi->saved_regs[D3_REGNUM] ? 4 : 0);
        adjust += (fi->saved_regs[A2_REGNUM] ? 4 : 0);
        adjust += (fi->saved_regs[A3_REGNUM] ? 4 : 0);
!       if (am33_mode)
  	{
  	  adjust += (fi->saved_regs[E0_REGNUM + 5] ? 4 : 0);
  	  adjust += (fi->saved_regs[E0_REGNUM + 4] ? 4 : 0);
--- 563,569 ----
        adjust += (fi->saved_regs[D3_REGNUM] ? 4 : 0);
        adjust += (fi->saved_regs[A2_REGNUM] ? 4 : 0);
        adjust += (fi->saved_regs[A3_REGNUM] ? 4 : 0);
!       if (AM33_MODE)
  	{
  	  adjust += (fi->saved_regs[E0_REGNUM + 5] ? 4 : 0);
  	  adjust += (fi->saved_regs[E0_REGNUM + 4] ? 4 : 0);
*************** mn10300_pop_frame (struct frame_info *fr
*** 611,618 ****
     order on the stack.  */
  
  CORE_ADDR
! mn10300_push_arguments (int nargs, value_ptr *args, CORE_ADDR sp,
! 			unsigned char struct_return, CORE_ADDR struct_addr)
  {
    int argnum = 0;
    int len = 0;
--- 631,638 ----
     order on the stack.  */
  
  CORE_ADDR
! mn10300_push_arguments (int nargs, struct value **args, CORE_ADDR sp,
! 			int struct_return, CORE_ADDR struct_addr)
  {
    int argnum = 0;
    int len = 0;
*************** mn10300_frame_saved_pc (struct frame_inf
*** 729,735 ****
    adjust += (fi->saved_regs[D3_REGNUM] ? 4 : 0);
    adjust += (fi->saved_regs[A2_REGNUM] ? 4 : 0);
    adjust += (fi->saved_regs[A3_REGNUM] ? 4 : 0);
!   if (am33_mode)
      {
        adjust += (fi->saved_regs[E0_REGNUM + 5] ? 4 : 0);
        adjust += (fi->saved_regs[E0_REGNUM + 4] ? 4 : 0);
--- 749,755 ----
    adjust += (fi->saved_regs[D3_REGNUM] ? 4 : 0);
    adjust += (fi->saved_regs[A2_REGNUM] ? 4 : 0);
    adjust += (fi->saved_regs[A3_REGNUM] ? 4 : 0);
!   if (AM33_MODE)
      {
        adjust += (fi->saved_regs[E0_REGNUM + 5] ? 4 : 0);
        adjust += (fi->saved_regs[E0_REGNUM + 4] ? 4 : 0);
*************** mn10300_virtual_frame_pointer (CORE_ADDR
*** 794,820 ****
      }
  }
  
! /* This can be made more generic later.  */
! static void
! set_machine_hook (char *filename)
  {
!   int i;
  
!   if (bfd_get_mach (exec_bfd) == bfd_mach_mn10300
!       || bfd_get_mach (exec_bfd) == 0)
!     {
!       mn10300_register_names = mn10300_generic_register_names;
!     }
  
!   am33_mode = 0;
!   if (bfd_get_mach (exec_bfd) == bfd_mach_am33)
      {
! 
!       mn10300_register_names = am33_register_names;
        am33_mode = 1;
!     }
! }
  
  void
  _initialize_mn10300_tdep (void)
  {
--- 814,891 ----
      }
  }
  
! static int
! mn10300_reg_struct_has_addr (int gcc_p, struct type *type)
  {
!   return (TYPE_LENGTH (type) > 8);
! }
  
! /* Dump out the mn10300 speciic architecture information. */
  
! static void
! mn10300_dump_tdep (struct gdbarch *current_gdbarch, struct ui_file *file)
! {
!   struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
!   fprintf_unfiltered (file, "mn10300_dump_tdep: am33_mode = %d\n",
! 		      tdep->am33_mode);
! }
! 
! static struct gdbarch *
! mn10300_gdbarch_init (struct gdbarch_info info,
! 		      struct gdbarch_list *arches)
! {
!   struct gdbarch *gdbarch;
!   struct gdbarch_tdep *tdep = NULL;
!   int am33_mode;
!   gdbarch_register_name_ftype *register_name;
!   int mach;
!   int num_regs;
! 
!   arches = gdbarch_list_lookup_by_info (arches, &info);
!   if (arches != NULL)
!     return arches->gdbarch;
!   tdep = xmalloc (sizeof (struct gdbarch_tdep));
!   gdbarch = gdbarch_alloc (&info, tdep);
! 
!   if (info.bfd_arch_info != NULL
!       && info.bfd_arch_info->arch == bfd_arch_mips)
!     mach = info.bfd_arch_info->mach;
!   else
!     mach = 0;
!   switch (mach)
      {
!     case 0:
!       am33_mode = 0;
!       register_name = mn10300_generic_register_name;
!       num_regs = 32;
!       break;
!     case bfd_mach_am33:
        am33_mode = 1;
!       register_name = am33_register_name;
!       num_regs = 32;
!       break;
!     default:
!       internal_error ("mn10300_gdbarch_init: Unknown mn10300 variant");
!       return NULL; /* keep GCC happy. */
!     }
! 
!   set_gdbarch_call_dummy_p (gdbarch, 1);
!   set_gdbarch_register_name (gdbarch, register_name);
!   set_gdbarch_use_generic_dummy_frames (gdbarch, 1);
!   set_gdbarch_call_dummy_breakpoint_offset_p (gdbarch, 0);
!   set_gdbarch_call_dummy_stack_adjust_p (gdbarch, 0);
!   set_gdbarch_get_saved_register (gdbarch, generic_get_saved_register);
!   set_gdbarch_push_arguments (gdbarch, mn10300_push_arguments);
!   set_gdbarch_push_return_address (gdbarch, mn10300_push_return_address);
!   set_gdbarch_frame_chain_valid (gdbarch, generic_file_frame_chain_valid);
!   set_gdbarch_reg_struct_has_addr (gdbarch, mn10300_reg_struct_has_addr);
!   set_gdbarch_save_dummy_frame_tos (gdbarch, generic_save_dummy_frame_tos);
!   set_gdbarch_num_regs (gdbarch, num_regs);
!   tdep->am33_mode = am33_mode;
  
+   return gdbarch;
+ }
+  
  void
  _initialize_mn10300_tdep (void)
  {
*************** _initialize_mn10300_tdep (void)
*** 822,826 ****
  
    tm_print_insn = print_insn_mn10300;
  
!   specify_exec_file_hook (set_machine_hook);
  }
--- 893,897 ----
  
    tm_print_insn = print_insn_mn10300;
  
!   register_gdbarch_init (bfd_arch_mn10300, mn10300_gdbarch_init);
  }
Index: config/mn10300/tm-mn10300.h
===================================================================
RCS file: /cvs/src/src/gdb/config/mn10300/tm-mn10300.h,v
retrieving revision 1.2
diff -p -r1.2 tm-mn10300.h
*** tm-mn10300.h	2000/05/28 01:12:37	1.2
--- tm-mn10300.h	2000/08/11 07:51:25
***************
*** 1,5 ****
  /* Parameters for execution on a Matsushita mn10300 processor.
!    Copyright 1996, 1997 Free Software Foundation, Inc. 
  
     Contributed by Geoffrey Noer <noer@cygnus.com>
  
--- 1,5 ----
  /* Parameters for execution on a Matsushita mn10300 processor.
!    Copyright 1996, 1997, 2000 Free Software Foundation, Inc. 
  
     Contributed by Geoffrey Noer <noer@cygnus.com>
  
***************
*** 20,25 ****
--- 20,27 ----
     Foundation, Inc., 59 Temple Place - Suite 330,
     Boston, MA 02111-1307, USA.  */
  
+ #define GDB_MULTI_ARCH 1
+ 
  /* The mn10300 is little endian.  */
  #define TARGET_BYTE_ORDER_DEFAULT LITTLE_ENDIAN
  
***************
*** 38,46 ****
  
  #define REGISTER_BYTES (NUM_REGS * REGISTER_SIZE)
  
- extern char *mn10300_register_name (int regnr);
- #define REGISTER_NAME(i) (mn10300_register_name (i))
- 
  #define D2_REGNUM 2
  #define D3_REGNUM 3
  #define A2_REGNUM 6
--- 40,45 ----
*************** extern CORE_ADDR mn10300_push_return_add
*** 141,147 ****
  
  extern CORE_ADDR
  mn10300_push_arguments (int, struct value **, CORE_ADDR,
! 			unsigned char, CORE_ADDR);
  #define PUSH_ARGUMENTS(NARGS, ARGS, SP, STRUCT_RETURN, STRUCT_ADDR) \
    (mn10300_push_arguments (NARGS, ARGS, SP, STRUCT_RETURN, STRUCT_ADDR))
  
--- 140,146 ----
  
  extern CORE_ADDR
  mn10300_push_arguments (int, struct value **, CORE_ADDR,
! 			int, CORE_ADDR);
  #define PUSH_ARGUMENTS(NARGS, ARGS, SP, STRUCT_RETURN, STRUCT_ADDR) \
    (mn10300_push_arguments (NARGS, ARGS, SP, STRUCT_RETURN, STRUCT_ADDR))
  

Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]