diff options
author | Nick Alcock <nick.alcock@oracle.com> | 2020-11-20 13:34:04 +0000 |
---|---|---|
committer | Nick Alcock <nick.alcock@oracle.com> | 2020-11-20 13:34:12 +0000 |
commit | 97a2a623d0193dbfc92d92545b63aaffd6099272 (patch) | |
tree | 4467ff62484008adf7eb1596909465cd727201a9 /libctf | |
parent | libctf, include: CTF-archive-wide symbol lookup (diff) | |
download | binutils-gdb-97a2a623d0193dbfc92d92545b63aaffd6099272.tar.gz binutils-gdb-97a2a623d0193dbfc92d92545b63aaffd6099272.tar.bz2 binutils-gdb-97a2a623d0193dbfc92d92545b63aaffd6099272.zip |
libctf, include: add ctf_getsymsect and ctf_getstrsect
libctf has long provided ctf_getdatasect, which hands back a pointer to
the CTF section a (read-only) dict came from. But it has no such
functions to return pointers to the ELF symbol table or string table
it's working from, which is unfortunate because several libctf functions
(ctf_open, ctf_fdopen, and ctf_bfdopen) figure out which string and
symbol table to use themselves, and don't tell the user what they
decided, so the caller can't agree on which symtab to use with libctf
even if it wanted to.
Add a pair of functions to return the symtab and strtab in use. Like
ctf_getdatasect, these return ctf_sect_t structures by value, filled
with all-NULL/0 content if a symtab or strtab is not being used.
include/ChangeLog
2020-11-20 Nick Alcock <nick.alcock@oracle.com>
* ctf-api.h (ctf_getsymsect): New.
(ctf_getstrsect): Likewise.
libctf/ChangeLog
2020-11-20 Nick Alcock <nick.alcock@oracle.com>
* ctf-open.c (ctf_getsymsect): New.
(ctf_getstrsect): Likewise.
* libctf.ver: Add them.
Diffstat (limited to 'libctf')
-rw-r--r-- | libctf/ChangeLog | 6 | ||||
-rw-r--r-- | libctf/ctf-open.c | 12 | ||||
-rw-r--r-- | libctf/libctf.ver | 3 |
3 files changed, 21 insertions, 0 deletions
diff --git a/libctf/ChangeLog b/libctf/ChangeLog index deca027786d..685c06a0142 100644 --- a/libctf/ChangeLog +++ b/libctf/ChangeLog @@ -1,5 +1,11 @@ 2020-11-20 Nick Alcock <nick.alcock@oracle.com> + * ctf-open.c (ctf_getsymsect): New. + (ctf_getstrsect): Likewise. + * libctf.ver: Add them. + +2020-11-20 Nick Alcock <nick.alcock@oracle.com> + * ctf-impl.h (struct ctf_archive_internal) <ctfi_dicts>: New, dicts the archive machinery has opened and cached. <ctfi_symdicts>: New, cache of dicts containing symbols looked up. diff --git a/libctf/ctf-open.c b/libctf/ctf-open.c index 3281c678ac4..ecf27eeeb21 100644 --- a/libctf/ctf-open.c +++ b/libctf/ctf-open.c @@ -1854,6 +1854,18 @@ ctf_getdatasect (const ctf_dict_t *fp) return fp->ctf_data; } +ctf_sect_t +ctf_getsymsect (const ctf_dict_t *fp) +{ + return fp->ctf_symtab; +} + +ctf_sect_t +ctf_getstrsect (const ctf_dict_t *fp) +{ + return fp->ctf_strtab; +} + /* Return the CTF handle for the parent CTF dict, if one exists. Otherwise return NULL to indicate this dict has no imported parent. */ ctf_dict_t * diff --git a/libctf/libctf.ver b/libctf/libctf.ver index f0633f26c4c..cfecc894350 100644 --- a/libctf/libctf.ver +++ b/libctf/libctf.ver @@ -190,4 +190,7 @@ LIBCTF_1.1 { ctf_arc_lookup_symbol; ctf_arc_flush_caches; + + ctf_getsymsect; + ctf_getstrsect; } LIBCTF_1.0; |