2003-01-07 Andrew Cagney <cagney@redhat.com>
[deliverable/binutils-gdb.git] / gdb / mn10200-tdep.c
index f8637e89c39a550ec05e0dd207b29fb9089d10c2..1e6827bb9c5541b1afe76e081fe2a5c1f0e63245 100644 (file)
@@ -1,5 +1,5 @@
 /* Target-dependent code for the Matsushita MN10200 for GDB, the GNU debugger.
-   Copyright 1997 Free Software Foundation, Inc.
+   Copyright 1997, 1998, 1999, 2000, 2001 Free Software Foundation, Inc.
 
    This file is part of GDB.
 
 #include "defs.h"
 #include "frame.h"
 #include "inferior.h"
-#include "obstack.h"
 #include "target.h"
 #include "value.h"
 #include "bfd.h"
 #include "gdb_string.h"
 #include "gdbcore.h"
 #include "symfile.h"
+#include "regcache.h"
 
 
 /* Should call_function allocate stack space for a struct return?  */
 int
-mn10200_use_struct_convention (gcc_p, type)
-     int gcc_p;
-     struct type *type;
+mn10200_use_struct_convention (int gcc_p, struct type *type)
 {
   return (TYPE_NFIELDS (type) > 1 || TYPE_LENGTH (type) > 8);
 }
@@ -112,12 +110,10 @@ mn10200_use_struct_convention (gcc_p, type)
 #define NO_MORE_FRAMES 0x8
 
 static CORE_ADDR
-mn10200_analyze_prologue (fi, pc)
-     struct frame_info *fi;
-     CORE_ADDR pc;
+mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR pc)
 {
   CORE_ADDR func_addr, func_end, addr, stop;
-  CORE_ADDR stack_size;
+  CORE_ADDR stack_size = 0;
   unsigned char buf[4];
   int status;
   char *name;
@@ -125,7 +121,7 @@ mn10200_analyze_prologue (fi, pc)
 
   /* Use the PC in the frame if it's provided to look up the
      start of this function.  */
-  pc = (fi ? fi->pc : pc);
+  pc = (fi ? get_frame_pc (fi) : pc);
 
   /* Find the start of this function.  */
   status = find_pc_partial_function (pc, &name, &func_addr, &func_end);
@@ -151,35 +147,35 @@ mn10200_analyze_prologue (fi, pc)
      been deallocated.
 
      fi->frame is bogus, we need to fix it.  */
-  if (fi && fi->pc + 1 == func_end)
+  if (fi && get_frame_pc (fi) + 1 == func_end)
     {
-      status = target_read_memory (fi->pc, buf, 1);
+      status = target_read_memory (get_frame_pc (fi), buf, 1);
       if (status != 0)
        {
          if (fi->next == NULL)
-           fi->frame = read_sp ();
-         return fi->pc;
+           deprecated_update_frame_base_hack (fi, read_sp ());
+         return get_frame_pc (fi);
        }
 
       if (buf[0] == 0xfe)
        {
          if (fi->next == NULL)
-           fi->frame = read_sp ();
-         return fi->pc;
+           deprecated_update_frame_base_hack (fi, read_sp ());
+         return get_frame_pc (fi);
        }
     }
 
   /* Similarly if we're stopped on the first insn of a prologue as our
      frame hasn't been allocated yet.  */
-  if (fi && fi->pc == func_addr)
+  if (fi && get_frame_pc (fi) == func_addr)
     {
       if (fi->next == NULL)
-       fi->frame = read_sp ();
-      return fi->pc;
+       deprecated_update_frame_base_hack (fi, read_sp ());
+      return get_frame_pc (fi);
     }
 
   /* Figure out where to stop scanning.  */
-  stop = fi ? fi->pc : func_end;
+  stop = fi ? get_frame_pc (fi) : func_end;
 
   /* Don't walk off the end of the function.  */
   stop = stop > func_end ? func_end : stop;
@@ -191,7 +187,7 @@ mn10200_analyze_prologue (fi, pc)
   if (status != 0)
     {
       if (fi && fi->next == NULL && fi->status & MY_FRAME_IN_SP)
-       fi->frame = read_sp ();
+       deprecated_update_frame_base_hack (fi, read_sp ());
       return addr;
     }
 
@@ -222,7 +218,7 @@ mn10200_analyze_prologue (fi, pc)
          /* We still haven't allocated our local stack.  Handle this
             as if we stopped on the first or last insn of a function.   */
          if (fi && fi->next == NULL)
-           fi->frame = read_sp ();
+           deprecated_update_frame_base_hack (fi, read_sp ());
          return addr;
        }
 
@@ -230,7 +226,7 @@ mn10200_analyze_prologue (fi, pc)
       if (status != 0)
        {
          if (fi && fi->next == NULL)
-           fi->frame = read_sp ();
+           deprecated_update_frame_base_hack (fi, read_sp ());
          return addr;
        }
       if (buf[0] == 0xf2 && buf[1] == 0x7e)
@@ -249,7 +245,7 @@ mn10200_analyze_prologue (fi, pc)
       else
        {
          if (fi && fi->next == NULL)
-           fi->frame = read_sp ();
+           deprecated_update_frame_base_hack (fi, read_sp ());
          return addr;
        }
     }
@@ -267,7 +263,7 @@ mn10200_analyze_prologue (fi, pc)
   if (status != 0)
     {
       if (fi && fi->next == NULL && (fi->status & MY_FRAME_IN_SP))
-       fi->frame = read_sp ();
+       deprecated_update_frame_base_hack (fi, read_sp ());
       return addr;
     }
   if (buf[0] == 0xd3)
@@ -279,7 +275,7 @@ mn10200_analyze_prologue (fi, pc)
       if (addr >= stop)
        {
          if (fi && fi->next == NULL && (fi->status & MY_FRAME_IN_SP))
-           fi->frame = read_sp () - stack_size;
+           deprecated_update_frame_base_hack (fi, read_sp () - stack_size);
          return addr;
        }
     }
@@ -289,7 +285,7 @@ mn10200_analyze_prologue (fi, pc)
       if (status != 0)
        {
          if (fi && fi->next == NULL && (fi->status & MY_FRAME_IN_SP))
-           fi->frame = read_sp ();
+           deprecated_update_frame_base_hack (fi, read_sp ());
          return addr;
        }
       stack_size = extract_signed_integer (buf, 2);
@@ -299,7 +295,7 @@ mn10200_analyze_prologue (fi, pc)
       if (addr >= stop)
        {
          if (fi && fi->next == NULL && (fi->status & MY_FRAME_IN_SP))
-           fi->frame = read_sp () - stack_size;
+           deprecated_update_frame_base_hack (fi, read_sp () - stack_size);
          return addr;
        }
     }
@@ -309,7 +305,7 @@ mn10200_analyze_prologue (fi, pc)
       if (status != 0)
        {
          if (fi && fi->next == NULL && (fi->status & MY_FRAME_IN_SP))
-           fi->frame = read_sp ();
+           deprecated_update_frame_base_hack (fi, read_sp ());
          return addr;
        }
       stack_size = extract_signed_integer (buf, 3);
@@ -319,7 +315,7 @@ mn10200_analyze_prologue (fi, pc)
       if (addr >= stop)
        {
          if (fi && fi->next == NULL && (fi->status & MY_FRAME_IN_SP))
-           fi->frame = read_sp () - stack_size;
+           deprecated_update_frame_base_hack (fi, read_sp () - stack_size);
          return addr;
        }
     }
@@ -338,7 +334,7 @@ mn10200_analyze_prologue (fi, pc)
       if (status != 0)
        {
          if (fi && fi->next == NULL && (fi->status & MY_FRAME_IN_SP))
-           fi->frame = read_sp ();
+           deprecated_update_frame_base_hack (fi, read_sp ());
          return addr;
        }
 
@@ -350,7 +346,7 @@ mn10200_analyze_prologue (fi, pc)
       if (status == 0)
        {
          if (fi && fi->next == NULL && (fi->status & MY_FRAME_IN_SP))
-           fi->frame = read_sp ();
+           deprecated_update_frame_base_hack (fi, read_sp ());
          return addr;
        }
 
@@ -366,7 +362,7 @@ mn10200_analyze_prologue (fi, pc)
          if (fi && fi->next == NULL)
            {
              fi->stack_size -= 16;
-             fi->frame = read_sp () - fi->stack_size;
+             deprecated_update_frame_base_hack (fi, read_sp () - fi->stack_size);
            }
          return addr;
        }
@@ -379,7 +375,7 @@ mn10200_analyze_prologue (fi, pc)
       if (status != 0)
        {
          if (fi && fi->next == NULL && (fi->status & MY_FRAME_IN_SP))
-           fi->frame = read_sp ();
+           deprecated_update_frame_base_hack (fi, read_sp ());
          return addr;
        }
 
@@ -391,7 +387,7 @@ mn10200_analyze_prologue (fi, pc)
       if (status == 0)
        {
          if (fi && fi->next == NULL && (fi->status & MY_FRAME_IN_SP))
-           fi->frame = read_sp ();
+           deprecated_update_frame_base_hack (fi, read_sp ());
          return addr;
        }
 
@@ -407,7 +403,7 @@ mn10200_analyze_prologue (fi, pc)
          if (fi && fi->next == NULL && (fi->status & MY_FRAME_IN_SP))
            {
              fi->stack_size -= 16;
-             fi->frame = read_sp () - fi->stack_size;
+             deprecated_update_frame_base_hack (fi, read_sp () - fi->stack_size);
            }
          return addr;
        }
@@ -425,7 +421,7 @@ mn10200_analyze_prologue (fi, pc)
 
       /* Update fi->frame if necessary.  */
       if (fi && fi->next == NULL)
-       fi->frame = read_sp () - fi->stack_size;
+       deprecated_update_frame_base_hack (fi, read_sp () - fi->stack_size);
 
       /* After the out of line prologue, there may be another
          stack adjustment for the outgoing arguments.
@@ -439,10 +435,10 @@ mn10200_analyze_prologue (fi, pc)
        {
          if (fi)
            {
-             fi->fsr.regs[2] = fi->frame + fi->stack_size + 4;
-             fi->fsr.regs[3] = fi->frame + fi->stack_size + 8;
-             fi->fsr.regs[5] = fi->frame + fi->stack_size + 12;
-             fi->fsr.regs[6] = fi->frame + fi->stack_size + 16;
+             fi->fsr.regs[2] = get_frame_base (fi) + fi->stack_size + 4;
+             fi->fsr.regs[3] = get_frame_base (fi) + fi->stack_size + 8;
+             fi->fsr.regs[5] = get_frame_base (fi) + fi->stack_size + 12;
+             fi->fsr.regs[6] = get_frame_base (fi) + fi->stack_size + 16;
            }
          return addr;
        }
@@ -459,10 +455,10 @@ mn10200_analyze_prologue (fi, pc)
            {
              if (fi)
                {
-                 fi->fsr.regs[2] = fi->frame + fi->stack_size + 4;
-                 fi->fsr.regs[3] = fi->frame + fi->stack_size + 8;
-                 fi->fsr.regs[5] = fi->frame + fi->stack_size + 12;
-                 fi->fsr.regs[6] = fi->frame + fi->stack_size + 16;
+                 fi->fsr.regs[2] = get_frame_base (fi) + fi->stack_size + 4;
+                 fi->fsr.regs[3] = get_frame_base (fi) + fi->stack_size + 8;
+                 fi->fsr.regs[5] = get_frame_base (fi) + fi->stack_size + 12;
+                 fi->fsr.regs[6] = get_frame_base (fi) + fi->stack_size + 16;
                }
              return addr;
            }
@@ -476,10 +472,10 @@ mn10200_analyze_prologue (fi, pc)
            {
              if (fi && fi->next == NULL)
                {
-                 fi->fsr.regs[2] = fi->frame + fi->stack_size + 4;
-                 fi->fsr.regs[3] = fi->frame + fi->stack_size + 8;
-                 fi->fsr.regs[5] = fi->frame + fi->stack_size + 12;
-                 fi->fsr.regs[6] = fi->frame + fi->stack_size + 16;
+                 fi->fsr.regs[2] = get_frame_base (fi) + fi->stack_size + 4;
+                 fi->fsr.regs[3] = get_frame_base (fi) + fi->stack_size + 8;
+                 fi->fsr.regs[5] = get_frame_base (fi) + fi->stack_size + 12;
+                 fi->fsr.regs[6] = get_frame_base (fi) + fi->stack_size + 16;
                }
              return addr;
            }
@@ -492,16 +488,16 @@ mn10200_analyze_prologue (fi, pc)
       /* Now that we know the size of the outgoing arguments, fix
          fi->frame again if this is the innermost frame.  */
       if (fi && fi->next == NULL)
-       fi->frame -= outgoing_args_size;
+       deprecated_update_frame_base_hack (fi, get_frame_base (fi) - outgoing_args_size);
 
       /* Note the register save information and update the stack
          size for this frame too.  */
       if (fi)
        {
-         fi->fsr.regs[2] = fi->frame + fi->stack_size + 4;
-         fi->fsr.regs[3] = fi->frame + fi->stack_size + 8;
-         fi->fsr.regs[5] = fi->frame + fi->stack_size + 12;
-         fi->fsr.regs[6] = fi->frame + fi->stack_size + 16;
+         fi->fsr.regs[2] = get_frame_base (fi) + fi->stack_size + 4;
+         fi->fsr.regs[3] = get_frame_base (fi) + fi->stack_size + 8;
+         fi->fsr.regs[5] = get_frame_base (fi) + fi->stack_size + 12;
+         fi->fsr.regs[6] = get_frame_base (fi) + fi->stack_size + 16;
          fi->stack_size += outgoing_args_size;
        }
       /* There can be no more prologue insns, so return now.  */
@@ -514,7 +510,7 @@ mn10200_analyze_prologue (fi, pc)
      need to fix fi->frame so that backtracing, find_frame_saved_regs,
      etc work correctly.  */
   if (fi && fi->next == NULL && (fi->status & MY_FRAME_IN_SP) != 0)
-    fi->frame = read_sp () - fi->stack_size;
+    deprecated_update_frame_base_hack (fi, read_sp () - fi->stack_size);
 
   /* And last we have the register saves.  These are relatively
      simple because they're physically done off the stack pointer,
@@ -538,7 +534,7 @@ mn10200_analyze_prologue (fi, pc)
          status = target_read_memory (addr + 2, buf, 1);
          if (status != 0)
            return addr;
-         fi->fsr.regs[2] = (fi->frame + stack_size
+         fi->fsr.regs[2] = (get_frame_base (fi) + stack_size
                             + extract_signed_integer (buf, 1));
        }
       addr += 3;
@@ -555,7 +551,7 @@ mn10200_analyze_prologue (fi, pc)
          status = target_read_memory (addr + 2, buf, 1);
          if (status != 0)
            return addr;
-         fi->fsr.regs[3] = (fi->frame + stack_size
+         fi->fsr.regs[3] = (get_frame_base (fi) + stack_size
                             + extract_signed_integer (buf, 1));
        }
       addr += 3;
@@ -572,7 +568,7 @@ mn10200_analyze_prologue (fi, pc)
          status = target_read_memory (addr + 1, buf, 1);
          if (status != 0)
            return addr;
-         fi->fsr.regs[5] = (fi->frame + stack_size
+         fi->fsr.regs[5] = (get_frame_base (fi) + stack_size
                             + extract_signed_integer (buf, 1));
        }
       addr += 2;
@@ -589,7 +585,7 @@ mn10200_analyze_prologue (fi, pc)
          status = target_read_memory (addr + 1, buf, 1);
          if (status != 0)
            return addr;
-         fi->fsr.regs[6] = (fi->frame + stack_size
+         fi->fsr.regs[6] = (get_frame_base (fi) + stack_size
                             + extract_signed_integer (buf, 1));
          fi->status &= ~CALLER_A2_IN_A0;
        }
@@ -609,10 +605,11 @@ mn10200_analyze_prologue (fi, pc)
    stack pointer that was in use at the time the function call was made?  */
 
 CORE_ADDR
-mn10200_frame_chain (fi)
-     struct frame_info *fi;
+mn10200_frame_chain (struct frame_info *fi)
 {
-  struct frame_info dummy_frame;
+  struct frame_info *dummy_frame = deprecated_frame_xmalloc ();
+  struct cleanup *old_chain = make_cleanup (xfree, dummy_frame);
+  CORE_ADDR ret;
 
   /* Walk through the prologue to determine the stack size,
      location of saved registers, end of the prologue, etc.  */
@@ -643,39 +640,40 @@ mn10200_frame_chain (fi)
 
      So we set up a dummy frame and call mn10200_analyze_prologue to
      find stuff for us.  */
-  dummy_frame.pc = FRAME_SAVED_PC (fi);
-  dummy_frame.frame = fi->frame;
-  memset (dummy_frame.fsr.regs, '\000', sizeof dummy_frame.fsr.regs);
-  dummy_frame.status = 0;
-  dummy_frame.stack_size = 0;
-  mn10200_analyze_prologue (&dummy_frame);
-
-  if (dummy_frame.status & MY_FRAME_IN_FP)
+  deprecated_update_frame_pc_hack (dummy_frame, FRAME_SAVED_PC (fi));
+  deprecated_update_frame_base_hack (dummy_frame, get_frame_base (fi));
+  memset (dummy_frame->fsr.regs, '\000', sizeof dummy_frame->fsr.regs);
+  dummy_frame->status = 0;
+  dummy_frame->stack_size = 0;
+  mn10200_analyze_prologue (dummy_frame, 0);
+
+  if (dummy_frame->status & MY_FRAME_IN_FP)
     {
       /* Our caller has a frame pointer.  So find the frame in $a2, $a0,
          or in the stack.  */
       if (fi->fsr.regs[6])
-       return (read_memory_integer (fi->fsr.regs[FP_REGNUM], REGISTER_SIZE)
-               & 0xffffff);
+       ret = (read_memory_integer (fi->fsr.regs[FP_REGNUM], REGISTER_SIZE)
+              & 0xffffff);
       else if (fi->status & CALLER_A2_IN_A0)
-       return read_register (4);
+       ret = read_register (4);
       else
-       return read_register (FP_REGNUM);
+       ret = read_register (FP_REGNUM);
     }
   else
     {
       /* Our caller does not have a frame pointer.  So his frame starts
          at the base of our frame (fi->frame) + <his size> + 4 (saved pc).  */
-      return fi->frame + -dummy_frame.stack_size + 4;
+      ret = get_frame_base (fi) + -dummy_frame->stack_size + 4;
     }
+  do_cleanups (old_chain);
+  return ret;
 }
 
 /* Function: skip_prologue
    Return the address of the first inst past the prologue of the function.  */
 
 CORE_ADDR
-mn10200_skip_prologue (pc)
-     CORE_ADDR pc;
+mn10200_skip_prologue (CORE_ADDR pc)
 {
   /* We used to check the debug symbols, but that can lose if
      we have a null prologue.  */
@@ -687,12 +685,13 @@ mn10200_skip_prologue (pc)
    command, or the call dummy breakpoint gets hit.  */
 
 void
-mn10200_pop_frame (frame)
-     struct frame_info *frame;
+mn10200_pop_frame (struct frame_info *frame)
 {
   int regnum;
 
-  if (PC_IN_CALL_DUMMY (frame->pc, frame->frame, frame->frame))
+  if (DEPRECATED_PC_IN_CALL_DUMMY (get_frame_pc (frame),
+                                  get_frame_base (frame),
+                                  get_frame_base (frame)))
     generic_pop_dummy_frame ();
   else
     {
@@ -710,7 +709,7 @@ mn10200_pop_frame (frame)
          }
 
       /* Actually cut back the stack.  */
-      write_register (SP_REGNUM, FRAME_FP (frame));
+      write_register (SP_REGNUM, get_frame_base (frame));
 
       /* Don't we need to set the PC?!?  XXX FIXME.  */
     }
@@ -724,12 +723,8 @@ mn10200_pop_frame (frame)
    order on the stack.  */
 
 CORE_ADDR
-mn10200_push_arguments (nargs, args, sp, struct_return, struct_addr)
-     int nargs;
-     value_ptr *args;
-     CORE_ADDR sp;
-     unsigned char struct_return;
-     CORE_ADDR struct_addr;
+mn10200_push_arguments (int nargs, struct value **args, CORE_ADDR sp,
+                       unsigned char struct_return, CORE_ADDR struct_addr)
 {
   int argnum = 0;
   int len = 0;
@@ -833,9 +828,7 @@ mn10200_push_arguments (nargs, args, sp, struct_return, struct_addr)
    Needed for targets where we don't actually execute a JSR/BSR instruction */
 
 CORE_ADDR
-mn10200_push_return_address (pc, sp)
-     CORE_ADDR pc;
-     CORE_ADDR sp;
+mn10200_push_return_address (CORE_ADDR pc, CORE_ADDR sp)
 {
   unsigned char buf[4];
 
@@ -849,9 +842,7 @@ mn10200_push_return_address (pc, sp)
    call.  */
 
 CORE_ADDR
-mn10200_store_struct_return (addr, sp)
-     CORE_ADDR addr;
-     CORE_ADDR sp;
+mn10200_store_struct_return (CORE_ADDR addr, CORE_ADDR sp)
 {
   /* The structure return address is passed as the first argument.  */
   write_register (0, addr);
@@ -866,11 +857,10 @@ mn10200_store_struct_return (addr, sp)
    will be found.  */
 
 CORE_ADDR
-mn10200_frame_saved_pc (fi)
-     struct frame_info *fi;
+mn10200_frame_saved_pc (struct frame_info *fi)
 {
   /* The saved PC will always be at the base of the current frame.  */
-  return (read_memory_integer (fi->frame, REGISTER_SIZE) & 0xffffff);
+  return (read_memory_integer (get_frame_base (fi), REGISTER_SIZE) & 0xffffff);
 }
 
 /* Function: init_extra_frame_info
@@ -878,7 +868,7 @@ mn10200_frame_saved_pc (fi)
    registers.  Most of the work is done in mn10200_analyze_prologue().
 
    Note that when we are called for the last frame (currently active frame),
-   that fi->pc and fi->frame will already be setup.  However, fi->frame will
+   that get_frame_pc (fi) and fi->frame will already be setup.  However, fi->frame will
    be valid only if this routine uses FP.  For previous frames, fi-frame will
    always be correct.  mn10200_analyze_prologue will fix fi->frame if
    it's not valid.
@@ -888,11 +878,10 @@ mn10200_frame_saved_pc (fi)
    pointer just prior to calling the target function (see run_stack_dummy).  */
 
 void
-mn10200_init_extra_frame_info (fi)
-     struct frame_info *fi;
+mn10200_init_extra_frame_info (struct frame_info *fi)
 {
   if (fi->next)
-    fi->pc = FRAME_SAVED_PC (fi->next);
+    deprecated_update_frame_pc_hack (fi, FRAME_SAVED_PC (fi->next));
 
   memset (fi->fsr.regs, '\000', sizeof fi->fsr.regs);
   fi->status = 0;
@@ -902,7 +891,7 @@ mn10200_init_extra_frame_info (fi)
 }
 
 void
-_initialize_mn10200_tdep ()
+_initialize_mn10200_tdep (void)
 {
   tm_print_insn = print_insn_mn10200;
 }
This page took 0.033193 seconds and 4 git commands to generate.