diff options
author | Nicholas Duffek <nsd@redhat.com> | 2001-07-16 22:57:50 +0000 |
---|---|---|
committer | Nicholas Duffek <nsd@redhat.com> | 2001-07-16 22:57:50 +0000 |
commit | 9ed10b085173a0bd46b57430c9c9af6036f2d740 (patch) | |
tree | 6426b82eb0b5d7700ce4f1f1ae6cc3dc326d0ca6 /gdb/findvar.c | |
parent | 75fd9bc1ec6f7c44cea2dce02c996c07ab826af8 (diff) | |
download | binutils-9ed10b085173a0bd46b57430c9c9af6036f2d740.zip binutils-9ed10b085173a0bd46b57430c9c9af6036f2d740.tar.gz binutils-9ed10b085173a0bd46b57430c9c9af6036f2d740.tar.bz2 |
* findvar.c (read_var_value): Apply value_as_pointer() to
addresses retrieved from the target for LOC_BASEREG and
LOC_BASEREG_ARG variables.
Diffstat (limited to 'gdb/findvar.c')
-rw-r--r-- | gdb/findvar.c | 19 |
1 files changed, 6 insertions, 13 deletions
diff --git a/gdb/findvar.c b/gdb/findvar.c index 8faf2f1..28a8ce0 100644 --- a/gdb/findvar.c +++ b/gdb/findvar.c @@ -610,22 +610,15 @@ addresses have not been bound by the dynamic loader. Try again when executable i case LOC_BASEREG: case LOC_BASEREG_ARG: - { - char *buf = (char*) alloca (MAX_REGISTER_RAW_SIZE); - get_saved_register (buf, NULL, NULL, frame, SYMBOL_BASEREG (var), - NULL); - addr = extract_address (buf, REGISTER_RAW_SIZE (SYMBOL_BASEREG (var))); - addr += SYMBOL_VALUE (var); - break; - } - case LOC_THREAD_LOCAL_STATIC: { - char *buf = (char*) alloca (MAX_REGISTER_RAW_SIZE); + value_ptr regval; - get_saved_register (buf, NULL, NULL, frame, SYMBOL_BASEREG (var), - NULL); - addr = extract_address (buf, REGISTER_RAW_SIZE (SYMBOL_BASEREG (var))); + regval = value_from_register (lookup_pointer_type (type), + SYMBOL_BASEREG (var), frame); + if (regval == NULL) + error ("Value of base register not available."); + addr = value_as_pointer (regval); addr += SYMBOL_VALUE (var); break; } |