diff options
author | Nick Alcock <nick.alcock@oracle.com> | 2019-07-13 21:41:25 +0100 |
---|---|---|
committer | Nick Alcock <nick.alcock@oracle.com> | 2019-10-03 17:04:55 +0100 |
commit | eabb7154df3e97e9d808a8673953cc1ce708f3d4 (patch) | |
tree | ab9fd36c30115b6c8d19ec062f5f14e1e2860cd9 /include/ctf.h | |
parent | 886453cbbc86ba63d8ab1264e9684a7698243eeb (diff) | |
download | gdb-eabb7154df3e97e9d808a8673953cc1ce708f3d4.zip gdb-eabb7154df3e97e9d808a8673953cc1ce708f3d4.tar.gz gdb-eabb7154df3e97e9d808a8673953cc1ce708f3d4.tar.bz2 |
libctf: add linking of the variable section
The compiler describes the name and type of all file-scope variables in
this section. Merging it at link time requires using the type mapping
added in the previous commit to determine the appropriate type for the
variable in the output, given its type in the input: we check the shared
container first, and if the type doesn't exist there, it must be a
conflicted type in the per-CU child, and the variable should go there
too. We also put the variable in the per-CU child if a variable with
the same name but a different type already exists in the parent: we
ignore any such conflict in the child because CTF cannot represent such
things, nor can they happen unless a third-party linking program has
overridden the mapping of CU to CTF archive member name (using machinery
added in a later commit).
v3: rewritten using an algorithm that actually works in the case of
conflicting names. Some code motion from the next commit. Set
the per-CU parent name.
v4: check for strdup failure.
v5: fix tabdamage.
include/
* ctf-api.h (ECTF_INTERNAL): New.
libctf/
* ctf-link.c (ctf_create_per_cu): New, refactored out of...
(ctf_link_one_type): ... here, with parent-name setting added.
(check_variable): New.
(ctf_link_one_variable): Likewise.
(ctf_link_one_input_archive_member): Call it.
* ctf-error.c (_ctf_errlist): Updated with new errors.
Diffstat (limited to 'include/ctf.h')
0 files changed, 0 insertions, 0 deletions