diff options
author | Andrew Burgess <andrew.burgess@embecosm.com> | 2020-06-11 22:36:29 +0100 |
---|---|---|
committer | Andrew Burgess <andrew.burgess@embecosm.com> | 2020-06-23 22:17:19 +0100 |
commit | fbf42f4e6d04745fe615dce1abd0190b78e368a6 (patch) | |
tree | 5a2ea61b2d64947bc402ffa9609995603a46e096 /gdbsupport | |
parent | 20821f4ed1c3b93344a8a40e9344fe356c2605c2 (diff) | |
download | gdb-fbf42f4e6d04745fe615dce1abd0190b78e368a6.zip gdb-fbf42f4e6d04745fe615dce1abd0190b78e368a6.tar.gz gdb-fbf42f4e6d04745fe615dce1abd0190b78e368a6.tar.bz2 |
gdb: Print compatible information within print_xml_feature
The gdbsupport directory contains a helper class print_xml_feature
that is shared between gdb and gdbserver. This class is used for
printing an XML representation of a target_desc object.
Currently this class doesn't have the ability to print the
<compatible> entities that can appear within a target description, I
guess no targets have needed that functionality yet.
The print_xml_feature classes API is based around operating on the
target_desc class, however, the sharing between gdb and gdbserver is
purely textural, we rely on their being a class called target_desc in
both gdb and gdbserver, but there is no shared implementation. We
then have a set of functions declared that operate on an object of
type target_desc, and again these functions have completely separate
implementations.
Currently then the gdb version of target_desc contains a vector of
bfd_arch_info pointers which represents the compatible entries from a
target description. The gdbserver version of target_desc has no such
information. Further, the gdbserver code doesn't seem to include the
bfd headers, and so doesn't know about the bfd types.
I was reluctant to include the bfd headers into gdbserver just so I
can reference the compatible information, which isn't (currently) even
needed in gdbserver.
So, the approach I take in this patch is to wrap the compatible
information into a new helper class. This class is declared in the
gdbsupport library, but implemented separately in both gdb and
gdbserver.
In gdbserver the class is empty. The compatible information within
the gdbserver is an empty list, of empty classes.
In gdb the class contains a pointer to the bfd_arch_info object.
With this in place we can now add support to print_xml_feature for
printing the compatible information if it is present. In the
gdbserver code this will never happen, as the gdbserver never has any
compatible information. But in gdb, this code will trigger when
appropriate.
gdb/ChangeLog:
* target-descriptions.c (class tdesc_compatible_info): New class.
(struct target_desc): Change type of compatible vector.
(tdesc_compatible_p): Update for change in type of
target_desc::compatible.
(tdesc_compatible_info_list): New function.
(tdesc_compatible_info_arch_name): New function.
(tdesc_add_compatible): Update for change in type of
target_desc::compatible.
(print_c_tdesc::visit_pre): Likewise.
gdbserver/ChangeLog:
* tdesc.cc (struct tdesc_compatible_info): New struct.
(tdesc_compatible_info_list): New function.
(tdesc_compatible_info_arch_name): New function.
gdbsupport/ChangeLog:
* tdesc.cc (print_xml_feature::visit_pre): Print compatible
information.
* tdesc.h (struct tdesc_compatible_info): Declare new struct.
(tdesc_compatible_info_up): New typedef.
(tdesc_compatible_info_list): Declare new function.
(tdesc_compatible_info_arch_name): Declare new function.
Diffstat (limited to 'gdbsupport')
-rw-r--r-- | gdbsupport/ChangeLog | 9 | ||||
-rw-r--r-- | gdbsupport/tdesc.cc | 6 | ||||
-rw-r--r-- | gdbsupport/tdesc.h | 21 |
3 files changed, 36 insertions, 0 deletions
diff --git a/gdbsupport/ChangeLog b/gdbsupport/ChangeLog index 7c2c4bf..2e5cbba 100644 --- a/gdbsupport/ChangeLog +++ b/gdbsupport/ChangeLog @@ -1,3 +1,12 @@ +2020-06-23 Andrew Burgess <andrew.burgess@embecosm.com> + + * tdesc.cc (print_xml_feature::visit_pre): Print compatible + information. + * tdesc.h (struct tdesc_compatible_info): Declare new struct. + (tdesc_compatible_info_up): New typedef. + (tdesc_compatible_info_list): Declare new function. + (tdesc_compatible_info_arch_name): Declare new function. + 2020-05-25 Michael Weghorn <m.weghorn@posteo.de> * common-utils.cc, common-utils.h (stringify_argv): Drop diff --git a/gdbsupport/tdesc.cc b/gdbsupport/tdesc.cc index aaea8e0..63f41cb 100644 --- a/gdbsupport/tdesc.cc +++ b/gdbsupport/tdesc.cc @@ -392,6 +392,12 @@ void print_xml_feature::visit_pre (const target_desc *e) const char *osabi = tdesc_osabi_name (e); if (osabi != nullptr) string_appendf (*m_buffer, "<osabi>%s</osabi>", osabi); + + const std::vector<tdesc_compatible_info_up> &compatible_list + = tdesc_compatible_info_list (e); + for (const auto &c : compatible_list) + string_appendf (*m_buffer, "<compatible>%s</compatible>\n", + tdesc_compatible_info_arch_name (c)); #endif } diff --git a/gdbsupport/tdesc.h b/gdbsupport/tdesc.h index 3b1f1f5..0cdcf56 100644 --- a/gdbsupport/tdesc.h +++ b/gdbsupport/tdesc.h @@ -131,6 +131,27 @@ struct tdesc_reg : tdesc_element typedef std::unique_ptr<tdesc_reg> tdesc_reg_up; +/* Declaration of a structure that holds information about one + "compatibility" entry within a target description. */ + +struct tdesc_compatible_info; + +/* A pointer to a single piece of compatibility information. */ + +typedef std::unique_ptr<tdesc_compatible_info> tdesc_compatible_info_up; + +/* Return a vector of compatibility information pointers from the target + description TARGET_DESC. */ + +const std::vector<tdesc_compatible_info_up> &tdesc_compatible_info_list + (const target_desc *target_desc); + +/* Return the architecture name from a compatibility information + COMPATIBLE. */ + +const char *tdesc_compatible_info_arch_name + (const tdesc_compatible_info_up &compatible); + enum tdesc_type_kind { /* Predefined types. */ |