diff options
author | Pedro Alves <pedro@codesourcery.com> | 2011-03-18 18:42:40 +0000 |
---|---|---|
committer | Pedro Alves <pedro@codesourcery.com> | 2011-03-18 18:42:40 +0000 |
commit | 4a8a3091dd993a919822dc434546f8959d16a22c (patch) | |
tree | 87f11fa757b7c6b7b937896aa7799ae03ec7c323 /gdb/findvar.c | |
parent | ef749a8958424d7fde1db60719cdc6425831f9de (diff) | |
download | gdb-4a8a3091dd993a919822dc434546f8959d16a22c.tar.gz |
gdb/
* dwarf2loc.c (read_pieced_value): Handle get_frame_register_bytes
returning that the register piece is unavailable/optimized out.
(write_pieced_value): Handle get_frame_register_bytes returning
that the register piece is unavailable/optimized out when doing a
read-modify write of a bitfield.
* findvar.c (value_from_register): Handle get_frame_register_bytes
returning that the register piece is unavailable/optimized out.
* frame.c (get_frame_register_bytes): New parameters `optimizedp'
and `unavailablep'. Throw error on bad debug info. Use
frame_register instead of frame_register_read, to fill in the new
arguments.
* frame.h (get_frame_register_bytes): New parameters `optimizedp'
and `unavailablep'.
* valops.c: (value_assign): Adjust, and handle
get_frame_register_bytes failing.
* spu-tdep.c: Include exceptions.h.
(spu_software_single_step): Adjust, and handle
get_frame_register_bytes failing.
(spu_get_longjmp_target): Ditto.
* gdbarch.sh (register_to_value): Change to return int. New
parameters `optimizedp' and `unavailablep'.
* gdbarch.h, gdbarch.c: Regenerate.
* i386-tdep.c (i386_register_to_value): Adjust to new
gdbarch_register_to_value interface.
* i387-tdep.c (i387_register_to_value): Ditto.
* i387-tdep.h (i387_register_to_value): Ditto.
* alpha-tdep.c (alpha_register_to_value): Ditto.
* ia64-tdep.c (ia64_register_to_value): Ditto.
* m68k-tdep.c (m68k_register_to_value): Ditto.
* mips-tdep.c (mips_register_to_value): Ditto.
* rs6000-tdep.c (rs6000_register_to_value): Ditto.
Diffstat (limited to 'gdb/findvar.c')
-rw-r--r-- | gdb/findvar.c | 19 |
1 files changed, 15 insertions, 4 deletions
diff --git a/gdb/findvar.c b/gdb/findvar.c index 809a99e8a72..2b361efeda3 100644 --- a/gdb/findvar.c +++ b/gdb/findvar.c @@ -628,6 +628,7 @@ value_from_register (struct type *type, int regnum, struct frame_info *frame) struct gdbarch *gdbarch = get_frame_arch (frame); struct type *type1 = check_typedef (type); struct value *v; + int optim, unavail, ok; if (gdbarch_convert_register_p (gdbarch, regnum, type1)) { @@ -642,8 +643,9 @@ value_from_register (struct type *type, int regnum, struct frame_info *frame) VALUE_LVAL (v) = lval_register; VALUE_FRAME_ID (v) = get_frame_id (frame); VALUE_REGNUM (v) = regnum; - gdbarch_register_to_value (gdbarch, - frame, regnum, type1, value_contents_raw (v)); + ok = gdbarch_register_to_value (gdbarch, frame, regnum, type1, + value_contents_raw (v), &optim, + &unavail); } else { @@ -653,10 +655,19 @@ value_from_register (struct type *type, int regnum, struct frame_info *frame) v = gdbarch_value_from_register (gdbarch, type, regnum, frame); /* Get the data. */ - if (!get_frame_register_bytes (frame, regnum, value_offset (v), len, - value_contents_raw (v))) + ok = get_frame_register_bytes (frame, regnum, value_offset (v), len, + value_contents_raw (v), + &optim, &unavail); + } + + if (!ok) + { + if (optim) set_value_optimized_out (v, 1); + if (unavail) + mark_value_bytes_unavailable (v, 0, TYPE_LENGTH (type)); } + return v; } |