A corrupt ELF file can have broken program headers, in which case gelf_getphdr returns NULL. This could crash handle_dynamic_symtab while searching for the PT_DYNAMIC phdr. Fix this by checking whether gelf_phdr returns NULL.
* src/readelf.c (handle_dynamic_symtab): Check whether gelf_getphdr returns NULL. https://sourceware.org/bugzilla/show_bug.cgi?id=32655 Signed-off-by: Mark Wielaard <m...@klomp.org> --- src/readelf.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/readelf.c b/src/readelf.c index c43fda35075a..21b92a08a6b6 100644 --- a/src/readelf.c +++ b/src/readelf.c @@ -2912,7 +2912,7 @@ handle_dynamic_symtab (Ebl *ebl) for (size_t i = 0; i < phnum; ++i) { phdr = gelf_getphdr (ebl->elf, i, &phdr_mem); - if (phdr->p_type == PT_DYNAMIC) + if (phdr == NULL || phdr->p_type == PT_DYNAMIC) break; } if (phdr == NULL) -- 2.48.1