Fix runtime seg-fault in readelf when parsing a corrupt MIPS binary.
authorNick Clifton <nickc@redhat.com>
Mon, 3 Apr 2017 10:13:21 +0000 (11:13 +0100)
committerNick Clifton <nickc@redhat.com>
Mon, 3 Apr 2017 10:13:21 +0000 (11:13 +0100)
PR binutils/21344
* readelf.c (process_mips_specific): Check for an out of range GOT
entry before reading the module pointer.

binutils/ChangeLog
binutils/readelf.c

index dee35e5f381a03e7254d086b518d4f7f5f723f06..438ea7fcd1632d68ca8ff92490b52c59f4a01e17 100644 (file)
@@ -1,3 +1,9 @@
+2017-04-03  Nick Clifton  <nickc@redhat.com>
+
+       PR binutils/21344
+       * readelf.c (process_mips_specific): Check for an out of range GOT
+       entry before reading the module pointer.
+
 2017-04-03  Nick Clifton  <nickc@redhat.com>
 
        PR binutils/21343
index 47736d6e9342cefd701eff15d37b5ceedca0d944..3665221501c63944c7f9cf5b83a1ed811e29081b 100644 (file)
@@ -15464,14 +15464,24 @@ process_mips_specific (FILE * file)
       printf (_(" Lazy resolver\n"));
       if (ent == (bfd_vma) -1)
        goto got_print_fail;
-      if (data
-         && (byte_get (data + ent - pltgot, addr_size)
-             >> (addr_size * 8 - 1)) != 0)
-       {
-         ent = print_mips_got_entry (data, pltgot, ent, data_end);
-         printf (_(" Module pointer (GNU extension)\n"));
-         if (ent == (bfd_vma) -1)
-           goto got_print_fail;
+
+      if (data)
+       {
+         /* PR 21344 */
+         if (data + ent - pltgot > data_end - addr_size)
+           {
+             error (_("Invalid got entry - %#lx - overflows GOT table\n"), ent);
+             goto got_print_fail;
+           }
+         
+         if (byte_get (data + ent - pltgot, addr_size)
+             >> (addr_size * 8 - 1) != 0)
+           {
+             ent = print_mips_got_entry (data, pltgot, ent, data_end);
+             printf (_(" Module pointer (GNU extension)\n"));
+             if (ent == (bfd_vma) -1)
+               goto got_print_fail;
+           }
        }
       printf ("\n");