diff options
author | Alan Modra <amodra@gmail.com> | 2020-03-12 16:48:07 +1030 |
---|---|---|
committer | Alan Modra <amodra@gmail.com> | 2020-03-12 17:00:40 +1030 |
commit | 8fb879cd16a3e3d1fe93e333c4c720fd33bcc416 (patch) | |
tree | 03efd94bbbe09bef20ca21099f1697ae4bb89274 /binutils/readelf.c | |
parent | dd69bf7a78a489783c397f2552eeb7999defcb6a (diff) | |
download | gdb-8fb879cd16a3e3d1fe93e333c4c720fd33bcc416.zip gdb-8fb879cd16a3e3d1fe93e333c4c720fd33bcc416.tar.gz gdb-8fb879cd16a3e3d1fe93e333c4c720fd33bcc416.tar.bz2 |
asan: readelf leaks
* readelf.c (process_section_headers): Don't just set
filedata->section_headers NULL, free it first. Similarly for
dynamic_symbols, dynamic_strings, dynamic_syminfo and
symtab_shndx_list. Zero associated counts too.
(process_object): Free symtab_shndx_list.
(process_file): Free various allocated filedata tables.
Diffstat (limited to 'binutils/readelf.c')
-rw-r--r-- | binutils/readelf.c | 24 |
1 files changed, 23 insertions, 1 deletions
diff --git a/binutils/readelf.c b/binutils/readelf.c index 260ea33..d009b91 100644 --- a/binutils/readelf.c +++ b/binutils/readelf.c @@ -6117,6 +6117,7 @@ process_section_headers (Filedata * filedata) Elf_Internal_Shdr * section; unsigned int i; + free (filedata->section_headers); filedata->section_headers = NULL; if (filedata->file_header.e_shnum == 0) @@ -6172,10 +6173,20 @@ process_section_headers (Filedata * filedata) /* Scan the sections for the dynamic symbol table and dynamic string table and debug sections. */ + free (dynamic_symbols); dynamic_symbols = NULL; + num_dynamic_syms = 0; + free (dynamic_strings); dynamic_strings = NULL; + dynamic_strings_length = 0; + free (dynamic_syminfo); dynamic_syminfo = NULL; - symtab_shndx_list = NULL; + while (symtab_shndx_list != NULL) + { + elf_section_list *next = symtab_shndx_list->next; + free (symtab_shndx_list); + symtab_shndx_list = next; + } eh_addr_size = is_32bit_elf ? 4 : 8; switch (filedata->file_header.e_machine) @@ -20121,6 +20132,13 @@ process_object (Filedata * filedata) dynamic_section = NULL; } + while (symtab_shndx_list != NULL) + { + elf_section_list *next = symtab_shndx_list->next; + free (symtab_shndx_list); + symtab_shndx_list = next; + } + if (section_headers_groups) { free (section_headers_groups); @@ -20486,6 +20504,10 @@ process_file (char * file_name) } fclose (filedata->handle); + free (filedata->section_headers); + free (filedata->program_headers); + free (filedata->string_table); + free (filedata->dump_sects); free (filedata); return ret; |