]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
[GOLD] PowerPC64 TOC indirect to TOC relative segfault
authorAlan Modra <amodra@gmail.com>
Fri, 3 Feb 2017 08:48:37 +0000 (19:18 +1030)
committerAlan Modra <amodra@gmail.com>
Fri, 3 Feb 2017 09:37:46 +0000 (20:07 +1030)
* powerpc.cc (Powerpc_relobj::make_toc_relative): Don't crash
when no .toc section exists.

gold/ChangeLog
gold/powerpc.cc

index 1be238cab679e621d9e59f60d9cf78d44761156b..f36dae744ee11179fec920cc03a702b3c8e601bc 100644 (file)
@@ -1,3 +1,8 @@
+2017-02-03  Alan Modra  <amodra@gmail.com>
+
+       * powerpc.cc (Powerpc_relobj::make_toc_relative): Don't crash
+       when no .toc section exists.
+
 2017-01-23  Vladimir Radosavljevic  <Vladimir.Radosavljevic@imgtec.com>
 
        * mips.cc (Mips_output_data_plt::rel_plt): Remove const from return
index a67c33618bd5a28548213a9b3c2f459fe061960a..4abfcec16d6efa765310d71758beb0eba698b0ed 100644 (file)
@@ -1986,6 +1986,12 @@ Powerpc_relobj<size, big_endian>::make_toc_relative(
   if (size != 64)
     return false;
 
+  // With -mcmodel=medium code it is quite possible to have
+  // toc-relative relocs referring to objects outside the TOC.
+  // Don't try to look at a non-existent TOC.
+  if (this->toc_shndx() == 0)
+    return false;
+
   // Convert VALUE back to an address by adding got_base (see below),
   // then to an offset in the TOC by subtracting the TOC output
   // section address and the TOC output offset.  Since this TOC output