From: Nick Alcock Date: Mon, 8 Jun 2020 08:24:01 +0000 (+0100) Subject: libctf: add ctf_ref X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=2399827bfa1062c7f782499e6dcd9f988318d422;p=binutils-gdb.git libctf: add ctf_ref This allows you to bump the refcount on a ctf_file_t, so that you can smuggle it out of iterators which open and close the ctf_file_t for you around the loop body (like ctf_archive_iter). You still can't use this to preserve a ctf_file_t for longer than the lifetime of its containing entity (e.g. ctf_archive). include/ * ctf-api.h (ctf_ref): New. libctf/ * libctf.ver (ctf_ref): New. * ctf-open.c (ctf_ref): Implement it. --- diff --git a/include/ChangeLog b/include/ChangeLog index dd9d5e075ca..3e3bb0a7d4f 100644 --- a/include/ChangeLog +++ b/include/ChangeLog @@ -1,3 +1,7 @@ +2020-07-22 Nick Alcock + + * ctf-api.h (ctf_ref): New. + 2020-07-22 Nick Alcock * ctf-api.h (ctf_archive_count): New. diff --git a/include/ctf-api.h b/include/ctf-api.h index fb797a3346d..faa7b727fb8 100644 --- a/include/ctf-api.h +++ b/include/ctf-api.h @@ -285,6 +285,7 @@ extern ctf_file_t *ctf_simple_open (const char *, size_t, const char *, size_t, size_t, const char *, size_t, int *); extern ctf_file_t *ctf_bufopen (const ctf_sect_t *, const ctf_sect_t *, const ctf_sect_t *, int *); +extern void ctf_ref (ctf_file_t *); extern void ctf_file_close (ctf_file_t *); extern int ctf_arc_write (const char *, ctf_file_t **, size_t, diff --git a/libctf/ChangeLog b/libctf/ChangeLog index c22cba0d84a..84f82fa9a41 100644 --- a/libctf/ChangeLog +++ b/libctf/ChangeLog @@ -1,3 +1,8 @@ +2020-07-22 Nick Alcock + + * libctf.ver (ctf_ref): New. + * ctf-open.c (ctf_ref): Implement it. + 2020-07-22 Nick Alcock * ctf-inlines.h (ctf_forwardable_kind): New. diff --git a/libctf/ctf-open.c b/libctf/ctf-open.c index 05672f36498..b7846bd0014 100644 --- a/libctf/ctf-open.c +++ b/libctf/ctf-open.c @@ -1620,6 +1620,17 @@ bad: return NULL; } +/* Bump the refcount on the specified CTF container, to allow export of + ctf_file_t's from iterators that open and close the ctf_file_t around the + loop. (This does not extend their lifetime beyond that of the ctf_archive_t + in which they are contained.) */ + +void +ctf_ref (ctf_file_t *fp) +{ + fp->ctf_refcnt++; +} + /* Close the specified CTF container and free associated data structures. Note that ctf_file_close() is a reference counted operation: if the specified file is the parent of other active containers, its reference count will be greater diff --git a/libctf/libctf.ver b/libctf/libctf.ver index 375dee8fc77..93616d83691 100644 --- a/libctf/libctf.ver +++ b/libctf/libctf.ver @@ -24,6 +24,7 @@ LIBCTF_1.0 { ctf_simple_open; ctf_create; ctf_close; + ctf_ref; ctf_file_close; ctf_cuname;