]> git.ipfire.org Git - thirdparty/elfutils.git/commitdiff
nm: Guard against divide by zero in error check.
authorMark Wielaard <mjw@redhat.com>
Fri, 26 Dec 2014 18:36:31 +0000 (19:36 +0100)
committerMark Wielaard <mjw@redhat.com>
Mon, 12 Jan 2015 21:07:53 +0000 (22:07 +0100)
Also add section index number in error message.

https://bugzilla.redhat.com/show_bug.cgi?id=1170810

Reported-by: Alexander Cherepanov <cherepan@mccme.ru>
Signed-off-by: Mark Wielaard <mjw@redhat.com>
src/ChangeLog
src/nm.c

index 9da28532b1a41da017f194fc62bbdb65a2e85c11..904b3c99e911f6ca498df47ec1d8fee1de2e5ad3 100644 (file)
@@ -1,3 +1,8 @@
+2014-12-26  Mark Wielaard  <mjw@redhat.com>
+
+       * nm.c (show_symbols): Guard against divide by zero in error check.
+       Add section index number in error message.
+
 2014-12-26  Mark Wielaard  <mjw@redhat.com>
 
        * nm.c (handle_ar): Skip over /SYM64/ entries.
index be91459c2ec4f57e03645b8ea2fa71ca7958989a..915153fa2f2ed23cc2c7ee89f2757100790ab8ea 100644 (file)
--- a/src/nm.c
+++ b/src/nm.c
@@ -1169,14 +1169,17 @@ show_symbols (Ebl *ebl, GElf_Ehdr *ehdr, Elf_Scn *scn, Elf_Scn *xndxscn,
   size_t entsize = shdr->sh_entsize;
 
   /* Consistency checks.  */
-  if (entsize != gelf_fsize (ebl->elf, ELF_T_SYM, 1, ehdr->e_version))
+  if (entsize == 0
+      || entsize != gelf_fsize (ebl->elf, ELF_T_SYM, 1, ehdr->e_version))
     error (0, 0,
-          gettext ("%s: entry size in section `%s' is not what we expect"),
-          fullname, elf_strptr (ebl->elf, shstrndx, shdr->sh_name));
+          gettext ("%s: entry size in section %zd `%s' is not what we expect"),
+          fullname, elf_ndxscn (scn),
+          elf_strptr (ebl->elf, shstrndx, shdr->sh_name));
   else if (size % entsize != 0)
     error (0, 0,
-          gettext ("%s: size of section `%s' is not multiple of entry size"),
-          fullname, elf_strptr (ebl->elf, shstrndx, shdr->sh_name));
+          gettext ("%s: size of section %zd `%s' is not multiple of entry size"),
+          fullname, elf_ndxscn (scn),
+          elf_strptr (ebl->elf, shstrndx, shdr->sh_name));
 
   /* Compute number of entries.  Handle buggy entsize values.  */
   size_t nentries = size / (entsize ?: 1);