* gdbarch.sh (EXTRACT_STRUCT_VALUE_ADDRESS_P): Delete definition.
(EXTRACT_STRUCT_VALUE_ADDRESS): Change to a function with predicate. * gdbarch.h, gdbarch.c: Regenerate. * values.c (value_being_returned): Change the reference to EXTRACT_STRUCT_VALUE_ADDRESS_P to a function call.
This commit is contained in:
parent
09843d7f0c
commit
d6dd581ead
5 changed files with 40 additions and 28 deletions
|
@ -1,3 +1,12 @@
|
|||
2001-06-15 Andrew Cagney <ac131313@redhat.com>
|
||||
|
||||
* gdbarch.sh (EXTRACT_STRUCT_VALUE_ADDRESS_P): Delete definition.
|
||||
(EXTRACT_STRUCT_VALUE_ADDRESS): Change to a function with
|
||||
predicate.
|
||||
* gdbarch.h, gdbarch.c: Regenerate.
|
||||
* values.c (value_being_returned): Change the reference to
|
||||
EXTRACT_STRUCT_VALUE_ADDRESS_P to a function call.
|
||||
|
||||
2001-06-15 Joel Brobecker <brobecker@act-europe.fr>
|
||||
|
||||
* MAINTAINERS: Add Paul Hilfinger and Joel Brobecker to the
|
||||
|
|
|
@ -690,10 +690,7 @@ verify_gdbarch (struct gdbarch *gdbarch)
|
|||
&& (gdbarch->store_return_value == 0))
|
||||
internal_error (__FILE__, __LINE__,
|
||||
"gdbarch: verify_gdbarch: store_return_value invalid");
|
||||
if ((GDB_MULTI_ARCH >= 2)
|
||||
&& (gdbarch->extract_struct_value_address == 0))
|
||||
internal_error (__FILE__, __LINE__,
|
||||
"gdbarch: verify_gdbarch: extract_struct_value_address invalid");
|
||||
/* Skip verify of extract_struct_value_address, has predicate */
|
||||
if ((GDB_MULTI_ARCH >= 2)
|
||||
&& (gdbarch->use_struct_convention == 0))
|
||||
internal_error (__FILE__, __LINE__,
|
||||
|
@ -3696,6 +3693,12 @@ set_gdbarch_store_return_value (struct gdbarch *gdbarch,
|
|||
gdbarch->store_return_value = store_return_value;
|
||||
}
|
||||
|
||||
int
|
||||
gdbarch_extract_struct_value_address_p (struct gdbarch *gdbarch)
|
||||
{
|
||||
return gdbarch->extract_struct_value_address != 0;
|
||||
}
|
||||
|
||||
CORE_ADDR
|
||||
gdbarch_extract_struct_value_address (struct gdbarch *gdbarch, char *regbuf)
|
||||
{
|
||||
|
|
|
@ -1097,6 +1097,28 @@ extern void set_gdbarch_store_return_value (struct gdbarch *gdbarch, gdbarch_sto
|
|||
#endif
|
||||
#endif
|
||||
|
||||
#if defined (EXTRACT_STRUCT_VALUE_ADDRESS)
|
||||
/* Legacy for systems yet to multi-arch EXTRACT_STRUCT_VALUE_ADDRESS */
|
||||
#if !defined (EXTRACT_STRUCT_VALUE_ADDRESS_P)
|
||||
#define EXTRACT_STRUCT_VALUE_ADDRESS_P() (1)
|
||||
#endif
|
||||
#endif
|
||||
|
||||
/* Default predicate for non- multi-arch targets. */
|
||||
#if (!GDB_MULTI_ARCH) && !defined (EXTRACT_STRUCT_VALUE_ADDRESS_P)
|
||||
#define EXTRACT_STRUCT_VALUE_ADDRESS_P() (0)
|
||||
#endif
|
||||
|
||||
extern int gdbarch_extract_struct_value_address_p (struct gdbarch *gdbarch);
|
||||
#if (GDB_MULTI_ARCH > GDB_MULTI_ARCH_PARTIAL) || !defined (EXTRACT_STRUCT_VALUE_ADDRESS_P)
|
||||
#define EXTRACT_STRUCT_VALUE_ADDRESS_P() (gdbarch_extract_struct_value_address_p (current_gdbarch))
|
||||
#endif
|
||||
|
||||
/* Default (function) for non- multi-arch platforms. */
|
||||
#if (!GDB_MULTI_ARCH) && !defined (EXTRACT_STRUCT_VALUE_ADDRESS)
|
||||
#define EXTRACT_STRUCT_VALUE_ADDRESS(regbuf) (internal_error (__FILE__, __LINE__, "EXTRACT_STRUCT_VALUE_ADDRESS"), 0)
|
||||
#endif
|
||||
|
||||
typedef CORE_ADDR (gdbarch_extract_struct_value_address_ftype) (char *regbuf);
|
||||
extern CORE_ADDR gdbarch_extract_struct_value_address (struct gdbarch *gdbarch, char *regbuf);
|
||||
extern void set_gdbarch_extract_struct_value_address (struct gdbarch *gdbarch, gdbarch_extract_struct_value_address_ftype *extract_struct_value_address);
|
||||
|
@ -1812,17 +1834,6 @@ extern disassemble_info tm_print_insn_info;
|
|||
#define GDB_TARGET_IS_D10V (TARGET_ARCHITECTURE->arch == bfd_arch_d10v)
|
||||
|
||||
|
||||
/* Fallback definition for EXTRACT_STRUCT_VALUE_ADDRESS */
|
||||
#ifndef EXTRACT_STRUCT_VALUE_ADDRESS
|
||||
#define EXTRACT_STRUCT_VALUE_ADDRESS_P (0)
|
||||
#define EXTRACT_STRUCT_VALUE_ADDRESS(X) (internal_error (__FILE__, __LINE__, "gdbarch: EXTRACT_STRUCT_VALUE_ADDRESS"), 0)
|
||||
#else
|
||||
#ifndef EXTRACT_STRUCT_VALUE_ADDRESS_P
|
||||
#define EXTRACT_STRUCT_VALUE_ADDRESS_P (1)
|
||||
#endif
|
||||
#endif
|
||||
|
||||
|
||||
/* Set the dynamic target-system-dependent parameters (architecture,
|
||||
byte-order, ...) using information found in the BFD */
|
||||
|
||||
|
|
|
@ -476,7 +476,7 @@ f:2:D10V_CONVERT_IADDR_TO_RAW:CORE_ADDR:d10v_convert_iaddr_to_raw:CORE_ADDR x:x:
|
|||
#
|
||||
f:2:STORE_STRUCT_RETURN:void:store_struct_return:CORE_ADDR addr, CORE_ADDR sp:addr, sp:::0
|
||||
f:2:STORE_RETURN_VALUE:void:store_return_value:struct type *type, char *valbuf:type, valbuf:::0
|
||||
f:2:EXTRACT_STRUCT_VALUE_ADDRESS:CORE_ADDR:extract_struct_value_address:char *regbuf:regbuf:::0
|
||||
F:2:EXTRACT_STRUCT_VALUE_ADDRESS:CORE_ADDR:extract_struct_value_address:char *regbuf:regbuf:::0
|
||||
f:2:USE_STRUCT_CONVENTION:int:use_struct_convention:int gcc_p, struct type *value_type:gcc_p, value_type:::0
|
||||
#
|
||||
f:2:FRAME_INIT_SAVED_REGS:void:frame_init_saved_regs:struct frame_info *frame:frame::0:0
|
||||
|
@ -1043,17 +1043,6 @@ extern disassemble_info tm_print_insn_info;
|
|||
#define GDB_TARGET_IS_D10V (TARGET_ARCHITECTURE->arch == bfd_arch_d10v)
|
||||
|
||||
|
||||
/* Fallback definition for EXTRACT_STRUCT_VALUE_ADDRESS */
|
||||
#ifndef EXTRACT_STRUCT_VALUE_ADDRESS
|
||||
#define EXTRACT_STRUCT_VALUE_ADDRESS_P (0)
|
||||
#define EXTRACT_STRUCT_VALUE_ADDRESS(X) (internal_error (__FILE__, __LINE__, "gdbarch: EXTRACT_STRUCT_VALUE_ADDRESS"), 0)
|
||||
#else
|
||||
#ifndef EXTRACT_STRUCT_VALUE_ADDRESS_P
|
||||
#define EXTRACT_STRUCT_VALUE_ADDRESS_P (1)
|
||||
#endif
|
||||
#endif
|
||||
|
||||
|
||||
/* Set the dynamic target-system-dependent parameters (architecture,
|
||||
byte-order, ...) using information found in the BFD */
|
||||
|
||||
|
|
|
@ -1328,7 +1328,7 @@ value_being_returned (struct type *valtype, char *retbuf, int struct_return)
|
|||
CORE_ADDR addr;
|
||||
|
||||
/* If this is not defined, just use EXTRACT_RETURN_VALUE instead. */
|
||||
if (EXTRACT_STRUCT_VALUE_ADDRESS_P)
|
||||
if (EXTRACT_STRUCT_VALUE_ADDRESS_P ())
|
||||
if (struct_return)
|
||||
{
|
||||
addr = EXTRACT_STRUCT_VALUE_ADDRESS (retbuf);
|
||||
|
|
Loading…
Reference in a new issue