]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
Remove some uses of MAX_REGISTER_SIZE from mips-tdep.c
authorAlan Hayward <alan.hayward@arm.com>
Mon, 8 May 2017 08:40:07 +0000 (09:40 +0100)
committerAlan Hayward <alan.hayward@arm.com>
Mon, 8 May 2017 08:40:07 +0000 (09:40 +0100)
gdb/
* mips-tdep.c (mips_o32_return_value): Remove unused buffer.
(print_gp_register_row): Use get_frame_register_value.

gdb/ChangeLog
gdb/mips-tdep.c

index 1f3f6cbd186320eb30c46309572a460da6b1e261..fec072779541b1e66d3a2011bd02b3245c0290ca 100644 (file)
@@ -1,3 +1,8 @@
+2017-05-08  Alan Hayward  <alan.hayward@arm.com>
+
+       * mips-tdep.c (mips_o32_return_value): Remove unused buffer.
+       (print_gp_register_row): Use get_frame_register_value.
+
 2017-05-08  Alan Hayward  <alan.hayward@arm.com>
 
        * mips-linux-tdep.c (mips_supply_gregset): Use raw_supply_zeroed.
index f8e68090cfafbe4339b691ceda085a7ee7ffbc14..2f5a90be46b568826dc44cad7d8935afa1794cd1 100644 (file)
@@ -5759,7 +5759,6 @@ mips_o32_return_value (struct gdbarch *gdbarch, struct value *function,
       /* A struct that contains one or two floats.  Each value is part
          in the least significant part of their floating point
          register..  */
-      gdb_byte reg[MAX_REGISTER_SIZE];
       int regnum;
       int field;
       for (field = 0, regnum = mips_regnum (gdbarch)->fp0;
@@ -6474,7 +6473,8 @@ print_gp_register_row (struct ui_file *file, struct frame_info *frame,
 {
   struct gdbarch *gdbarch = get_frame_arch (frame);
   /* Do values for GP (int) regs.  */
-  gdb_byte raw_buffer[MAX_REGISTER_SIZE];
+  const gdb_byte *raw_buffer;
+  struct value *value;
   int ncols = (mips_abi_regsize (gdbarch) == 8 ? 4 : 8);    /* display cols
                                                               per row.  */
   int col, byte;
@@ -6533,9 +6533,12 @@ print_gp_register_row (struct ui_file *file, struct frame_info *frame,
        break;                  /* End row: large register.  */
 
       /* OK: get the data in raw format.  */
-      if (!deprecated_frame_register_read (frame, regnum, raw_buffer))
+      value = get_frame_register_value (frame, regnum);
+      if (value_optimized_out (value)
+       || !value_entirely_available (value))
        error (_("can't read register %d (%s)"),
               regnum, gdbarch_register_name (gdbarch, regnum));
+      raw_buffer = value_contents_all (value);
       /* pad small registers */
       for (byte = 0;
           byte < (mips_abi_regsize (gdbarch)