aboutsummaryrefslogtreecommitdiff
path: root/libctf
diff options
context:
space:
mode:
authorNick Alcock <nick.alcock@oracle.com>2021-03-02 15:10:05 +0000
committerNick Alcock <nick.alcock@oracle.com>2021-03-02 15:10:09 +0000
commit8e7e446446b2de0c44e453a298718a0411f47205 (patch)
treedf2cc2f2436e05cf6eaa192a46fff9c61881751c /libctf
parentcf6a0b989a57db81f1470560edf4dbfb1835c032 (diff)
downloadgdb-8e7e446446b2de0c44e453a298718a0411f47205.zip
gdb-8e7e446446b2de0c44e453a298718a0411f47205.tar.gz
gdb-8e7e446446b2de0c44e453a298718a0411f47205.tar.bz2
libctf: free ctf_dynsyms properly
In the "no symbols" case (commonplace for executables), we were freeing the ctf_dynsyms using free(), instead of ctf_dynhash_destroy(), leaking a little memory. (This is harmless in the common case of ld usage, but libctf might be used by persistent processes too.) libctf/ChangeLog 2021-03-02 Nick Alcock <nick.alcock@oracle.com> * ctf-link.c (ctf_link_shuffle_syms): Free ctf_dynsyms properly.
Diffstat (limited to 'libctf')
-rw-r--r--libctf/ChangeLog4
-rw-r--r--libctf/ctf-link.c2
2 files changed, 5 insertions, 1 deletions
diff --git a/libctf/ChangeLog b/libctf/ChangeLog
index f0a1754..8fa98c6 100644
--- a/libctf/ChangeLog
+++ b/libctf/ChangeLog
@@ -1,5 +1,9 @@
2021-03-02 Nick Alcock <nick.alcock@oracle.com>
+ * ctf-link.c (ctf_link_shuffle_syms): Free ctf_dynsyms properly.
+
+2021-03-02 Nick Alcock <nick.alcock@oracle.com>
+
* ctf-dump.c (ctf_dump_format_type): Fix signed/unsigned confusion.
2021-03-02 Nick Alcock <nick.alcock@oracle.com>
diff --git a/libctf/ctf-link.c b/libctf/ctf-link.c
index 05733a0..882d429 100644
--- a/libctf/ctf-link.c
+++ b/libctf/ctf-link.c
@@ -1580,7 +1580,7 @@ ctf_link_shuffle_syms (ctf_dict_t *fp)
if (!ctf_dynhash_elements (fp->ctf_dynsyms))
{
ctf_dprintf ("No symbols: not a final link.\n");
- free (fp->ctf_dynsyms);
+ ctf_dynhash_destroy (fp->ctf_dynsyms);
fp->ctf_dynsyms = NULL;
return 0;
}