From: Jim Blandy Date: Wed, 21 Aug 2002 17:24:31 +0000 (+0000) Subject: * valops.c (value_cast): Simplify and correct logic for doing a X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=d174216d52ba742b085f7b8184f485d9ceee020c;p=binutils-gdb.git * valops.c (value_cast): Simplify and correct logic for doing a static cast from a pointer to a base class to a pointer to a derived class. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index c072c1f3619..c06a825e11d 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,9 @@ +2002-08-21 Jim Blandy + + * valops.c (value_cast): Simplify and correct logic for doing a + static cast from a pointer to a base class to a pointer to a + derived class. + 2002-08-21 Andrew Cagney * infcmd.c (default_print_registers_info): Replace diff --git a/gdb/valops.c b/gdb/valops.c index 569c85b62cd..1eeedd32cf7 100644 --- a/gdb/valops.c +++ b/gdb/valops.c @@ -361,18 +361,11 @@ value_cast (struct type *type, struct value *arg2) value_zero (t1, not_lval), 0, t1, 1); if (v) { - struct value *v2 = value_ind (arg2); - VALUE_ADDRESS (v2) -= VALUE_ADDRESS (v) - + VALUE_OFFSET (v); - - /* JYG: adjust the new pointer value and - embedded offset. */ - v2->aligner.contents[0] -= VALUE_EMBEDDED_OFFSET (v); - VALUE_EMBEDDED_OFFSET (v2) = 0; - - v2 = value_addr (v2); - VALUE_TYPE (v2) = type; - return v2; + CORE_ADDR addr2 = value_as_address (arg2); + addr2 -= (VALUE_ADDRESS (v) + + VALUE_OFFSET (v) + + VALUE_EMBEDDED_OFFSET (v)); + return value_from_pointer (type, addr2); } } }