2003-01-07 Andrew Cagney <cagney@redhat.com>
[deliverable/binutils-gdb.git] / gdb / mn10200-tdep.c
index a8d7d72ef8ec45b3ce28589f522e08c9777b1f22..1e6827bb9c5541b1afe76e081fe2a5c1f0e63245 100644 (file)
@@ -121,7 +121,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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);
@@ -147,35 +147,35 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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;
@@ -187,7 +187,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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;
     }
 
@@ -218,7 +218,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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;
        }
 
@@ -226,7 +226,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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)
@@ -245,7 +245,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR pc)
       else
        {
          if (fi && fi->next == NULL)
-           fi->frame = read_sp ();
+           deprecated_update_frame_base_hack (fi, read_sp ());
          return addr;
        }
     }
@@ -263,7 +263,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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)
@@ -275,7 +275,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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;
        }
     }
@@ -285,7 +285,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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);
@@ -295,7 +295,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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;
        }
     }
@@ -305,7 +305,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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);
@@ -315,7 +315,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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;
        }
     }
@@ -334,7 +334,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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;
        }
 
@@ -346,7 +346,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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;
        }
 
@@ -362,7 +362,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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;
        }
@@ -375,7 +375,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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;
        }
 
@@ -387,7 +387,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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;
        }
 
@@ -403,7 +403,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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;
        }
@@ -421,7 +421,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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.
@@ -435,10 +435,10 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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;
        }
@@ -455,10 +455,10 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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;
            }
@@ -472,10 +472,10 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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;
            }
@@ -488,16 +488,16 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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.  */
@@ -510,7 +510,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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,
@@ -534,7 +534,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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;
@@ -551,7 +551,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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;
@@ -568,7 +568,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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;
@@ -585,7 +585,7 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR 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;
        }
@@ -607,7 +607,9 @@ mn10200_analyze_prologue (struct frame_info *fi, CORE_ADDR pc)
 CORE_ADDR
 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.  */
@@ -638,31 +640,33 @@ mn10200_frame_chain (struct frame_info *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, 0);
-
-  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
@@ -685,7 +689,9 @@ 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
     {
@@ -703,7 +709,7 @@ mn10200_pop_frame (struct frame_info *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.  */
     }
@@ -854,7 +860,7 @@ CORE_ADDR
 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
@@ -862,7 +868,7 @@ mn10200_frame_saved_pc (struct frame_info *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.
@@ -875,7 +881,7 @@ void
 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;
This page took 0.030687 seconds and 4 git commands to generate.