ARM: Migrate from 'regset_from_core_section' to 'iterate_over_regset_sections'
For ARM BSD targets, don't define the gdbarch method 'regset_from_core_section', but the iterator method instead. gdb/ChangeLog: * arm-tdep.h (armbsd_regset_from_core_section): Remove prototype. (armbsd_iterate_over_regset_sections): New prototype. * armbsd-tdep.c (armbsd_regset_from_core_section): Remove. (armbsd_iterate_over_regset_sections): New. * armobsd-tdep.c (armobsd_init_abi): Adjust gdbarch initialization.
This commit is contained in:
parent
dff2166ef9
commit
ed09174e35
@ -1,3 +1,12 @@
|
|||||||
|
2014-09-30 Andreas Arnez <arnez@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
* arm-tdep.h (armbsd_regset_from_core_section): Remove prototype.
|
||||||
|
(armbsd_iterate_over_regset_sections): New prototype.
|
||||||
|
* armbsd-tdep.c (armbsd_regset_from_core_section): Remove.
|
||||||
|
(armbsd_iterate_over_regset_sections): New.
|
||||||
|
* armobsd-tdep.c (armobsd_init_abi): Adjust gdbarch
|
||||||
|
initialization.
|
||||||
|
|
||||||
2014-09-30 Andreas Arnez <arnez@linux.vnet.ibm.com>
|
2014-09-30 Andreas Arnez <arnez@linux.vnet.ibm.com>
|
||||||
|
|
||||||
* alpha-linux-tdep.c (alpha_linux_regset_from_core_section): Remove.
|
* alpha-linux-tdep.c (alpha_linux_regset_from_core_section): Remove.
|
||||||
|
@ -341,9 +341,11 @@ extern int arm_process_record (struct gdbarch *gdbarch,
|
|||||||
/* Return the appropriate register set for the core section identified
|
/* Return the appropriate register set for the core section identified
|
||||||
by SECT_NAME and SECT_SIZE. */
|
by SECT_NAME and SECT_SIZE. */
|
||||||
|
|
||||||
extern const struct regset *
|
extern void
|
||||||
armbsd_regset_from_core_section (struct gdbarch *gdbarch,
|
armbsd_iterate_over_regset_sections (struct gdbarch *gdbarch,
|
||||||
const char *sect_name, size_t sect_size);
|
iterate_over_regset_sections_cb *cb,
|
||||||
|
void *cb_data,
|
||||||
|
const struct regcache *regcache);
|
||||||
|
|
||||||
/* Target descriptions. */
|
/* Target descriptions. */
|
||||||
extern struct target_desc *tdesc_arm_with_m;
|
extern struct target_desc *tdesc_arm_with_m;
|
||||||
|
@ -107,18 +107,14 @@ static const struct regset armbsd_fpregset =
|
|||||||
armbsd_supply_fpregset
|
armbsd_supply_fpregset
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Return the appropriate register set for the core section identified
|
/* Iterate over supported core file register note sections. */
|
||||||
by SECT_NAME and SECT_SIZE. */
|
|
||||||
|
|
||||||
const struct regset *
|
void
|
||||||
armbsd_regset_from_core_section (struct gdbarch *gdbarch,
|
armbsd_iterate_over_regset_sections (struct gdbarch *gdbarch,
|
||||||
const char *sect_name, size_t sect_size)
|
iterate_over_regset_sections_cb *cb,
|
||||||
|
void *cb_data,
|
||||||
|
const struct regcache *regcache)
|
||||||
{
|
{
|
||||||
if (strcmp (sect_name, ".reg") == 0 && sect_size >= ARMBSD_SIZEOF_GREGS)
|
cb (".reg", ARMBSD_SIZEOF_GREGS, &armbsd_gregset, NULL, cb_data);
|
||||||
return &armbsd_gregset;
|
cb (".reg2", ARMBSD_SIZEOF_FPREGS, &armbsd_fpregset, NULL, cb_data);
|
||||||
|
|
||||||
if (strcmp (sect_name, ".reg2") == 0 && sect_size >= ARMBSD_SIZEOF_FPREGS)
|
|
||||||
return &armbsd_fpregset;
|
|
||||||
|
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
|
@ -91,8 +91,8 @@ armobsd_init_abi (struct gdbarch_info info,
|
|||||||
tdep->jb_pc = 24;
|
tdep->jb_pc = 24;
|
||||||
tdep->jb_elt_size = 4;
|
tdep->jb_elt_size = 4;
|
||||||
|
|
||||||
set_gdbarch_regset_from_core_section
|
set_gdbarch_iterate_over_regset_sections
|
||||||
(gdbarch, armbsd_regset_from_core_section);
|
(gdbarch, armbsd_iterate_over_regset_sections);
|
||||||
|
|
||||||
/* OpenBSD/arm uses -fpcc-struct-return by default. */
|
/* OpenBSD/arm uses -fpcc-struct-return by default. */
|
||||||
tdep->struct_return = pcc_struct_return;
|
tdep->struct_return = pcc_struct_return;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user