asan: leak in bfd_section_from_shdr

* elf.c (bfd_section_from_shdr): Free sections_being_created.
	Use bfd_zmalloc.
This commit is contained in:
Alan Modra
2020-11-03 10:23:03 +10:30
parent af61e84fd2
commit 706d7ce948
2 changed files with 10 additions and 3 deletions

View File

@ -1,3 +1,8 @@
2020-11-03 Alan Modra <amodra@gmail.com>
* elf.c (bfd_section_from_shdr): Free sections_being_created.
Use bfd_zmalloc.
2020-11-02 Alan Modra <amodra@gmail.com>
PR 15146

View File

@ -2061,17 +2061,19 @@ bfd_section_from_shdr (bfd *abfd, unsigned int shindex)
rather than being held in a static pointer. */
if (sections_being_created_abfd != abfd)
sections_being_created = NULL;
{
free (sections_being_created);
sections_being_created = NULL;
}
if (sections_being_created == NULL)
{
size_t amt = elf_numsections (abfd) * sizeof (bfd_boolean);
/* PR 26005: Do not use bfd_zalloc here as the memory might
be released before the bfd has been fully scanned. */
sections_being_created = (bfd_boolean *) bfd_malloc (amt);
sections_being_created = (bfd_boolean *) bfd_zmalloc (amt);
if (sections_being_created == NULL)
return FALSE;
memset (sections_being_created, FALSE, amt);
sections_being_created_abfd = abfd;
}
if (sections_being_created [shindex])