diff options
author | Nick Alcock <nick.alcock@oracle.com> | 2024-03-26 13:04:20 +0000 |
---|---|---|
committer | Nick Alcock <nick.alcock@oracle.com> | 2024-04-19 16:14:47 +0100 |
commit | 483546ce4f36a93d3fb711f2261b15b75871f3f9 (patch) | |
tree | 7022abc55beff5b441d1c959ae52cbc18bafaf82 /libctf/ctf-impl.h | |
parent | cf9da3b0b6a6ae9d71ba36898a5e39710150f85e (diff) | |
download | binutils-483546ce4f36a93d3fb711f2261b15b75871f3f9.zip binutils-483546ce4f36a93d3fb711f2261b15b75871f3f9.tar.gz binutils-483546ce4f36a93d3fb711f2261b15b75871f3f9.tar.bz2 |
libctf: make ctf_serialize() actually serialize
ctf_serialize() evolved from the old ctf_update(), which mutated the
in-memory CTF dict to make all the dynamic in-memory types into static,
unchanging written-to-the-dict types (by deserializing and reserializing
it): back in the days when you could only do type lookups on static types,
this meant you could see all the types you added recently, at the small,
small cost of making it impossible to change those older types ever again
and inducing an amortized O(n^2) cost if you actually wanted to add
references to types you added at arbitrary times to later types.
It also reset things so that ctf_discard() would throw away only types you
added after the most recent ctf_update() call.
Some time ago this was all changed so that you could look up dynamic types
just as easily as static types: ctf_update() changed so that only its
visible side-effect of affecting ctf_discard() remained: the old
ctf_update() was renamed to ctf_serialize(), made internal to libctf, and
called from the various functions that wrote files out.
... but it was still working by serializing and deserializing the entire
dict, swapping out its guts with the newly-serialized copy in an invasive
and horrible fashion that coupled ctf_serialize() to almost every field in
the ctf_dict_t. This is totally useless, and fixing it is easy: just rip
all that code out and have ctf_serialize return a serialized representation,
and let everything use that directly. This simplifies most of its callers
significantly.
(It also points up another bug: ctf_gzwrite() failed to call ctf_serialize()
at all, so it would only ever work for a dict you just ctf_write_mem()ed
yourself, just for its invisible side-effect of serializing the dict!)
This lets us simplify away a bunch of internal-only open-side functionality
for overriding the syn_ext_strtab and some just-added functionality for
forcing in an existing atoms table, without loss of functionality, and lets
us lift the restriction on reserializing a dict that was ctf_open()ed rather
than being ctf_create()d: it's now perfectly OK to open a dict, modify it
(except for adding members to existing structs, unions, or enums, which
fails with -ECTF_RDONLY), and write it out again, just as one would expect.
libctf/
* ctf-serialize.c (ctf_symtypetab_sect_sizes): Fix typos.
(ctf_type_sect_size): Add static type sizes too.
(ctf_serialize): Return the new dict rather than updating the
existing dict. No longer fail for dicts with static types;
copy them onto the start of the new types table.
(ctf_gzwrite): Actually serialize before gzwriting.
(ctf_write_mem): Improve forced (test-mode) endian-flipping:
flip dicts even if they are too small to be compressed.
Improve confusing variable naming.
* ctf-archive.c (arc_write_one_ctf): Don't bother to call
ctf_serialize: both the functions we call do so.
* ctf-string.c (ctf_str_create_atoms): Drop serializing case
(atoms arg).
* ctf-open.c (ctf_simple_open): Call ctf_bufopen directly.
(ctf_simple_open_internal): Delete.
(ctf_bufopen_internal): Delete/rename to ctf_bufopen: no
longer bother with syn_ext_strtab or forced atoms table,
serialization no longer needs them.
* ctf-create.c (ctf_create): Call ctf_bufopen directly.
* ctf-impl.h (ctf_str_create_atoms): Drop atoms arg.
(ctf_simple_open_internal): Delete.
(ctf_bufopen_internal): Likewise.
(ctf_serialize): Adjust.
* testsuite/libctf-lookup/add-to-opened.c: Adjust now that
this is supposed to work.
Diffstat (limited to 'libctf/ctf-impl.h')
-rw-r--r-- | libctf/ctf-impl.h | 19 |
1 files changed, 2 insertions, 17 deletions
diff --git a/libctf/ctf-impl.h b/libctf/ctf-impl.h index 3eef232..03e1a66 100644 --- a/libctf/ctf-impl.h +++ b/libctf/ctf-impl.h @@ -364,14 +364,7 @@ typedef struct ctf_dedup clients, who see it only as an opaque pointer. Modifications can therefore be made freely to this structure without regard to client versioning. The ctf_dict_t typedef appears in <ctf-api.h> and declares a forward tag. - (A ctf_file_t typedef also appears there, for historical reasons.) - - NOTE: ctf_serialize requires that everything inside of ctf_dict either be an - immediate value, a pointer to dynamically allocated data *outside* of the - ctf_dict itself, a pointer to statically allocated data, or specially handled - in ctf_serialize. If you add a pointer to ctf_dict that points to something - within the ctf_dict itself, you must make corresponding changes to - ctf_serialize. */ + (A ctf_file_t typedef also appears there, for historical reasons.) */ struct ctf_dict { @@ -735,7 +728,7 @@ extern const char *ctf_strraw (ctf_dict_t *, uint32_t); extern const char *ctf_strraw_explicit (ctf_dict_t *, uint32_t, ctf_strs_t *); extern const char *ctf_strptr_validate (ctf_dict_t *, uint32_t); -extern int ctf_str_create_atoms (ctf_dict_t *, ctf_dynhash_t *atoms); +extern int ctf_str_create_atoms (ctf_dict_t *); extern void ctf_str_free_atoms (ctf_dict_t *); extern uint32_t ctf_str_add (ctf_dict_t *, const char *); extern uint32_t ctf_str_add_ref (ctf_dict_t *, const char *, uint32_t *ref); @@ -760,15 +753,7 @@ extern void *ctf_set_open_errno (int *, int); extern void ctf_flip_header (ctf_header_t *); extern int ctf_flip (ctf_dict_t *, ctf_header_t *, unsigned char *, int); -extern ctf_dict_t *ctf_simple_open_internal (const char *, size_t, const char *, - size_t, size_t, - const char *, size_t, - ctf_dynhash_t *, ctf_dynhash_t *, int *); -extern ctf_dict_t *ctf_bufopen_internal (const ctf_sect_t *, const ctf_sect_t *, - const ctf_sect_t *, ctf_dynhash_t *, - ctf_dynhash_t *, int *); extern int ctf_import_unref (ctf_dict_t *fp, ctf_dict_t *pfp); -extern int ctf_serialize (ctf_dict_t *); _libctf_malloc_ extern void *ctf_mmap (size_t length, size_t offset, int fd); |