Commonise tdesc_feature and makes use of it in gdbserver tdesc
gdb/ * common/tdesc.c (tdesc_feature::accept): Move to here. (tdesc_feature::operator==): Likewise. (tdesc_create_reg): Likewise. * common/tdesc.h (tdesc_type_kind): Likewise. (struct tdesc_type): Likewise. (struct tdesc_feature): Likewise. * regformats/regdat.sh: Create a feature. * target-descriptions.c (tdesc_type_kind): Move from here. (tdesc_type): Likewise. (tdesc_type_up): Likewise. (tdesc_feature): Likewise. (tdesc_create_reg): Likewise. gdbserver/ * tdesc.c (~target_desc): Remove implictly deleted items. (init_target_desc): Iterate all features. (tdesc_get_features_xml): Use vector. (tdesc_create_feature): Create feature. * tdesc.h (tdesc_feature) Remove (target_desc): Add features.
This commit is contained in:
parent
ea3e7d7179
commit
82ec9bc705
8 changed files with 199 additions and 197 deletions
|
@ -33,3 +33,61 @@ tdesc_reg::tdesc_reg (struct tdesc_feature *feature, const std::string &name_,
|
|||
have easy access to the containing feature when we want it later. */
|
||||
tdesc_type = tdesc_named_type (feature, type.c_str ());
|
||||
}
|
||||
|
||||
void tdesc_feature::accept (tdesc_element_visitor &v) const
|
||||
{
|
||||
v.visit_pre (this);
|
||||
|
||||
for (const tdesc_type_up &type : types)
|
||||
type->accept (v);
|
||||
|
||||
for (const tdesc_reg_up ® : registers)
|
||||
reg->accept (v);
|
||||
|
||||
v.visit_post (this);
|
||||
}
|
||||
|
||||
bool tdesc_feature::operator== (const tdesc_feature &other) const
|
||||
{
|
||||
if (name != other.name)
|
||||
return false;
|
||||
|
||||
if (registers.size () != other.registers.size ())
|
||||
return false;
|
||||
|
||||
for (int ix = 0; ix < registers.size (); ix++)
|
||||
{
|
||||
const tdesc_reg_up ®1 = registers[ix];
|
||||
const tdesc_reg_up ®2 = other.registers[ix];
|
||||
|
||||
if (reg1 != reg2 && *reg1 != *reg2)
|
||||
return false;
|
||||
}
|
||||
|
||||
if (types.size () != other.types.size ())
|
||||
return false;
|
||||
|
||||
for (int ix = 0; ix < types.size (); ix++)
|
||||
{
|
||||
const tdesc_type_up &type1 = types[ix];
|
||||
const tdesc_type_up &type2 = other.types[ix];
|
||||
|
||||
if (type1 != type2 && *type1 != *type2)
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/* See common/tdesc.h. */
|
||||
|
||||
void
|
||||
tdesc_create_reg (struct tdesc_feature *feature, const char *name,
|
||||
int regnum, int save_restore, const char *group,
|
||||
int bitsize, const char *type)
|
||||
{
|
||||
tdesc_reg *reg = new tdesc_reg (feature, name, regnum, save_restore,
|
||||
group, bitsize, type);
|
||||
|
||||
feature->registers.emplace_back (reg);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue