Nothing uses it yet.
{
return 0;
}
+
+ULONGEST
+process_stratum_target::tdesc_parameter_value (regcache *regcache,
+ unsigned int param_id)
+{
+ error (_("Target does not support target description parameters."));
+}
+
+bool
+process_stratum_target::is_register_relevant_for_tdesc_parameter
+ (const target_desc *tdesc, int regnum)
+{
+ return false;
+}
Returns true if successful and false otherwise. */
virtual bool store_memtags (CORE_ADDR address, size_t len,
const gdb::byte_vector &tags, int type);
+
+
+ virtual ULONGEST tdesc_parameter_value (regcache *regcache,
+ unsigned int param_id);
+
+ virtual bool is_register_relevant_for_tdesc_parameter
+ (const target_desc *tdesc, int regnum);
};
extern process_stratum_target *the_target;
return the_target->thread_id_str (thread);
}
+static inline ULONGEST
+target_desc_parameter_value (regcache *regcache, unsigned int param_id)
+{
+ return the_target->tdesc_parameter_value (regcache, param_id);
+}
+
+static inline bool
+target_is_register_relevant_for_tdesc_parameter (const target_desc *tdesc,
+ int regnum)
+{
+ return the_target->is_register_relevant_for_tdesc_parameter (tdesc, regnum);
+}
+
#endif /* GDBSERVER_TARGET_H */
#endif
}
+/* Return bit size of given TYPE. */
+
+static unsigned int
+tdesc_type_bitsize (const tdesc_type *type)
+{
+ switch (type->kind) {
+ case TDESC_TYPE_INT8:
+ case TDESC_TYPE_UINT8:
+ return 8;
+ case TDESC_TYPE_IEEE_HALF:
+ case TDESC_TYPE_INT16:
+ case TDESC_TYPE_UINT16:
+ case TDESC_TYPE_BFLOAT16:
+ return 16;
+ case TDESC_TYPE_IEEE_SINGLE:
+ case TDESC_TYPE_INT32:
+ case TDESC_TYPE_UINT32:
+ return 32;
+ case TDESC_TYPE_IEEE_DOUBLE:
+ case TDESC_TYPE_INT64:
+ case TDESC_TYPE_UINT64:
+ return 64;
+ case TDESC_TYPE_I387_EXT:
+ return 80;
+ case TDESC_TYPE_ARM_FPA_EXT:
+ return 96;
+ case TDESC_TYPE_INT128:
+ case TDESC_TYPE_UINT128:
+ return 128;
+ default:
+ /* The other types require a gdbarch to determine their size. */
+ error ("Target description uses unsupported type in variable-size register.");
+ }
+}
+
+/* FIXME: Document. */
+
+std::optional<unsigned int>
+tdesc_parameter_id (const target_desc *tdesc, const char *feature,
+ const char *param_name)
+{
+ for (int i = 0; i < tdesc->parameters.size (); i++)
+ {
+ const tdesc_arch_parameter ¶meter = tdesc->parameters[i];
+ if (parameter.feature == feature && parameter.name == param_name)
+ return i;
+ }
+
+ return {};
+}
+
+/* FIXME: Document. */
+
+unsigned int
+tdesc_parameter_size (const target_desc *tdesc, unsigned param_id)
+{
+ return tdesc->parameters[param_id].size;
+}
+
void
init_target_desc (struct target_desc *tdesc,
const char **expedite_regs,
/* Go through all the features and populate reg_defs. */
for (const tdesc_feature_up &feature : tdesc->features)
- for (const tdesc_reg_up &treg : feature->registers)
- {
- int regnum = treg->target_regnum;
+ {
+ for (const tdesc_parameter_up ¶meter: feature->parameters)
+ tdesc->parameters.emplace_back (parameter->feature, parameter->name,
+ tdesc_type_bitsize (parameter->type) / 8);
- /* Register number will increase (possibly with gaps) or be zero. */
- gdb_assert (regnum == 0 || regnum >= tdesc->reg_defs.size ());
+ for (const tdesc_reg_up &treg : feature->registers)
+ {
+ int regnum = treg->target_regnum;
- if (regnum != 0)
- tdesc->reg_defs.resize (regnum, gdb::reg (offset));
+ /* Register number will increase (possibly with gaps) or be zero. */
+ gdb_assert (regnum == 0 || regnum >= tdesc->reg_defs.size ());
- tdesc->reg_defs.emplace_back (treg->name.c_str (), offset,
- treg->bitsize);
- offset += treg->bitsize;
- }
+ if (regnum != 0)
+ tdesc->reg_defs.resize (regnum, gdb::reg (offset));
+
+ tdesc->reg_defs.emplace_back (treg->name.c_str (), offset,
+ treg->bitsize);
+ offset += treg->bitsize;
+ }
+ }
tdesc->registers_size = offset / 8;
#include "regdef.h"
#include <vector>
+struct tdesc_arch_parameter
+{
+ tdesc_arch_parameter (std::string &feature_, std::string &name_,
+ unsigned int size_)
+ : feature (feature_), name (name_), size (size_)
+ {}
+
+ /* Feature to which the parameter belongs. */
+ std::string feature;
+
+ /* The name of the parameter. */
+ std::string name;
+
+ /* The size of a parameter value. */
+ unsigned int size;
+};
+
/* A target description. Inherit from tdesc_feature so that target_desc
can be used as tdesc_feature. */
/* XML features in this target description. */
std::vector<tdesc_feature_up> features;
+ /* The index into the vector is the internal ID for the parameter. */
+ std::vector<tdesc_arch_parameter> parameters;
+
#ifndef IN_PROCESS_AGENT
/* A vector of register names. These are the "expedite" registers:
registers whose values are sent along with stop replies. */
bool tdesc_contains_feature (const target_desc *tdesc,
const std::string &feature);
+/* FIXME: Document. */
+unsigned int tdesc_parameter_size (const target_desc *tdesc, unsigned param_id);
+
+/* FIXME: Document. */
+std::optional<unsigned int> tdesc_parameter_id (const target_desc *tdesc,
+ const char *feature,
+ const char *param_name);
+
#endif /* GDBSERVER_TDESC_H */
const tdesc_parameter &bitsize_parameter,
const char *type);
-/* Return internal ID of PARAMETER from FEATURE. */
-
-std::optional<unsigned int> tdesc_parameter_id (const target_desc *target_desc,
- const char *feature,
- const char *parameter);
-
/* Add PARAMETER to FEATURE. */
const tdesc_parameter & tdesc_create_parameter (tdesc_feature &feature,