From: Alan Modra Date: Wed, 21 Jun 2023 05:03:59 +0000 (+0930) Subject: elf32_arm_get_synthetic_symtab memory leak X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=08edd976116312550831cdfd3b5a4b069bdcca80;p=binutils-gdb.git elf32_arm_get_synthetic_symtab memory leak ARM get_synthetic_symtab reads .plt and caches that data. Caching the data doesn't make a lot of sense since get_synthetic_symtab is only called once per bfd, and the memory might be put to better use. It also leaks on closing the bfd. * elf32-arm.c (elf32_arm_get_synthetic_symtab): Don't cache plt contents. Free plt data before returning. --- diff --git a/bfd/elf32-arm.c b/bfd/elf32-arm.c index 2afe67abdf1..3b7cee3de1c 100644 --- a/bfd/elf32-arm.c +++ b/bfd/elf32-arm.c @@ -20073,15 +20073,9 @@ elf32_arm_get_synthetic_symtab (bfd *abfd, if (!elf32_arm_size_info.slurp_reloc_table (abfd, relplt, dynsyms, true)) return -1; - data = plt->contents; - if (data == NULL) - { - if (!bfd_get_full_section_contents (abfd, plt, &data) - || data == NULL) - return -1; - plt->contents = data; - plt->flags |= SEC_IN_MEMORY; - } + data = NULL; + if (!bfd_get_full_section_contents (abfd, plt, &data)) + return -1; count = NUM_SHDR_ENTRIES (hdr); size = count * sizeof (asymbol); @@ -20093,13 +20087,13 @@ elf32_arm_get_synthetic_symtab (bfd *abfd, size += sizeof ("+0x") - 1 + 8; } - s = *ret = (asymbol *) bfd_malloc (size); - if (s == NULL) - return -1; - offset = elf32_arm_plt0_size (abfd, data); - if (offset == (bfd_vma) -1) - return -1; + if (offset == (bfd_vma) -1 + || (s = *ret = (asymbol *) bfd_malloc (size)) == NULL) + { + free (data); + return -1; + } names = (char *) (s + count); p = relplt->relocation; @@ -20144,6 +20138,7 @@ elf32_arm_get_synthetic_symtab (bfd *abfd, offset += plt_size; } + free (data); return n; }