(struct gdbarch_tdep): Add struct_return member.
* arm-tdep.c (arm_return_value): Return
RETURN_VALUE_STRUCT_CONVENTION for aggregates when the ABI uses
pcc_struct_return.
(arm_gdbarch_init): Default to reg_struct_return.
* armobsd-tdep.c (armobsd_init_abi): Set pcc_struct_return.
+2006-08-01 Mark Kettenis <kettenis@gnu.org>
+
+ * arm-tdep.h (enum struct_return): New.
+ (struct gdbarch_tdep): Add struct_return member.
+ * arm-tdep.c (arm_return_value): Return
+ RETURN_VALUE_STRUCT_CONVENTION for aggregates when the ABI uses
+ pcc_struct_return.
+ (arm_gdbarch_init): Default to reg_struct_return.
+ * armobsd-tdep.c (armobsd_init_abi): Set pcc_struct_return.
+
2006-07-31 Mark Kettenis <kettenis@gnu.org>
* alpha-tdep.h (ALPHA_S0_REGNUM): New define.
2006-07-31 Mark Kettenis <kettenis@gnu.org>
* alpha-tdep.h (ALPHA_S0_REGNUM): New define.
struct regcache *regcache, gdb_byte *readbuf,
const gdb_byte *writebuf)
{
struct regcache *regcache, gdb_byte *readbuf,
const gdb_byte *writebuf)
{
+ struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
+
if (TYPE_CODE (valtype) == TYPE_CODE_STRUCT
|| TYPE_CODE (valtype) == TYPE_CODE_UNION
|| TYPE_CODE (valtype) == TYPE_CODE_ARRAY)
{
if (TYPE_CODE (valtype) == TYPE_CODE_STRUCT
|| TYPE_CODE (valtype) == TYPE_CODE_UNION
|| TYPE_CODE (valtype) == TYPE_CODE_ARRAY)
{
- if (arm_return_in_memory (gdbarch, valtype))
+ if (tdep->struct_return == pcc_struct_return
+ || arm_return_in_memory (gdbarch, valtype))
return RETURN_VALUE_STRUCT_CONVENTION;
}
return RETURN_VALUE_STRUCT_CONVENTION;
}
tdep->lowest_pc = 0x20;
tdep->jb_pc = -1; /* Longjump support not enabled by default. */
tdep->lowest_pc = 0x20;
tdep->jb_pc = -1; /* Longjump support not enabled by default. */
+ /* The default, for both APCS and AAPCS, is to return small
+ structures in registers. */
+ tdep->struct_return = reg_struct_return;
+
set_gdbarch_push_dummy_call (gdbarch, arm_push_dummy_call);
set_gdbarch_frame_align (gdbarch, arm_frame_align);
set_gdbarch_push_dummy_call (gdbarch, arm_push_dummy_call);
set_gdbarch_frame_align (gdbarch, arm_frame_align);
+/* Convention for returning structures. */
+
+enum struct_return
+{
+ pcc_struct_return, /* Return "short" structures in memory. */
+ reg_struct_return /* Return "short" structures in registers. */
+};
+
/* Target-dependent structure in gdbarch. */
struct gdbarch_tdep
{
/* Target-dependent structure in gdbarch. */
struct gdbarch_tdep
{
will be disabled. */
size_t jb_elt_size; /* And the size of each entry in the buf. */
will be disabled. */
size_t jb_elt_size; /* And the size of each entry in the buf. */
+ /* Convention for returning structures. */
+ enum struct_return struct_return;
+
/* Cached core file helpers. */
struct regset *gregset, *fpregset;
};
/* Cached core file helpers. */
struct regset *gregset, *fpregset;
};
#ifndef LOWEST_PC
#define LOWEST_PC (gdbarch_tdep (current_gdbarch)->lowest_pc)
#endif
#ifndef LOWEST_PC
#define LOWEST_PC (gdbarch_tdep (current_gdbarch)->lowest_pc)
#endif
tdep->jb_pc = 24;
tdep->jb_elt_size = 4;
tdep->jb_pc = 24;
tdep->jb_elt_size = 4;
+
+ /* OpenBSD/arm uses -fpcc-struct-return by default. */
+ tdep->struct_return = pcc_struct_return;