address size can be different from DW_OP_deref size
gdb/ChangeLog: * dwarf2expr.c (execute_stack_op) [DW_OP_deref]: Handle the case where ADDR_SIZE is different from TYPE_LENGTH (type).
This commit is contained in:
parent
164a5cb7bd
commit
325663dcd2
|
@ -1,3 +1,8 @@
|
|||
2011-06-03 Joel Brobecker <brobecker@adacore.com>
|
||||
|
||||
* dwarf2expr.c (execute_stack_op) [DW_OP_deref]: Handle
|
||||
the case where ADDR_SIZE is different from TYPE_LENGTH (type).
|
||||
|
||||
2011-06-03 Tom Tromey <tromey@redhat.com>
|
||||
|
||||
* python/py-inferior.c (python_inferior_exit): Use inferior's exit
|
||||
|
|
|
@ -877,6 +877,19 @@ execute_stack_op (struct dwarf_expr_context *ctx,
|
|||
type = address_type;
|
||||
|
||||
(ctx->read_mem) (ctx->baton, buf, addr, addr_size);
|
||||
|
||||
/* If the size of the object read from memory is different
|
||||
from the type length, we need to zero-extend it. */
|
||||
if (TYPE_LENGTH (type) != addr_size)
|
||||
{
|
||||
ULONGEST result =
|
||||
extract_unsigned_integer (buf, addr_size, byte_order);
|
||||
|
||||
buf = alloca (TYPE_LENGTH (type));
|
||||
store_unsigned_integer (buf, TYPE_LENGTH (type),
|
||||
byte_order, result);
|
||||
}
|
||||
|
||||
result_val = value_from_contents_and_address (type, buf, addr);
|
||||
break;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue