aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPedro Alves <palves@redhat.com>2011-01-28 15:42:01 +0000
committerPedro Alves <palves@redhat.com>2011-01-28 15:42:01 +0000
commitde15c4ab2db92fc9d3ac4cc264c42914db8a134f (patch)
treee53cfb923a5e1ad18d2e2020b451dd066b8823f4
parent1c79eb8a7d7126b5fcb734fb374be42a717d4373 (diff)
downloadgdb-de15c4ab2db92fc9d3ac4cc264c42914db8a134f.zip
gdb-de15c4ab2db92fc9d3ac4cc264c42914db8a134f.tar.gz
gdb-de15c4ab2db92fc9d3ac4cc264c42914db8a134f.tar.bz2
gdb/
* mips-tdep.c (mips_print_register): Use get_frame_register_value and val_print_scalar_formatted.
-rw-r--r--gdb/ChangeLog5
-rw-r--r--gdb/mips-tdep.c20
2 files changed, 13 insertions, 12 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index 21e04d6..8b07d70 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,3 +1,8 @@
+2011-01-28 Pedro Alves <pedro@codesourcery.com>
+
+ * mips-tdep.c (mips_print_register): Use get_frame_register_value
+ and val_print_scalar_formatted.
+
2011-01-27 Pedro Alves <pedro@codesourcery.com>
* tracepoint.c (tfile_read): New.
diff --git a/gdb/mips-tdep.c b/gdb/mips-tdep.c
index 1ab2e13..a2ca1ca 100644
--- a/gdb/mips-tdep.c
+++ b/gdb/mips-tdep.c
@@ -4683,9 +4683,9 @@ mips_print_register (struct ui_file *file, struct frame_info *frame,
int regnum)
{
struct gdbarch *gdbarch = get_frame_arch (frame);
- gdb_byte raw_buffer[MAX_REGISTER_SIZE];
int offset;
struct value_print_options opts;
+ struct value *val;
if (TYPE_CODE (register_type (gdbarch, regnum)) == TYPE_CODE_FLT)
{
@@ -4693,8 +4693,8 @@ mips_print_register (struct ui_file *file, struct frame_info *frame,
return;
}
- /* Get the data in raw format. */
- if (!frame_register_read (frame, regnum, raw_buffer))
+ val = get_frame_register_value (frame, regnum);
+ if (value_optimized_out (val))
{
fprintf_filtered (file, "%s: [Invalid]",
gdbarch_register_name (gdbarch, regnum));
@@ -4712,16 +4712,12 @@ mips_print_register (struct ui_file *file, struct frame_info *frame,
else
fprintf_filtered (file, ": ");
- if (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG)
- offset =
- register_size (gdbarch, regnum) - register_size (gdbarch, regnum);
- else
- offset = 0;
-
get_formatted_print_options (&opts, 'x');
- print_scalar_formatted (raw_buffer + offset,
- register_type (gdbarch, regnum), &opts, 0,
- file);
+ val_print_scalar_formatted (value_type (val),
+ value_contents_for_printing (val),
+ value_embedded_offset (val),
+ val,
+ &opts, 0, file);
}
/* Replacement for generic do_registers_info.