patches/binutils/2.20/100-ppc64-pie.patch
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Tue Jul 12 23:52:24 2011 +0200 (2011-07-12)
branch1.11
changeset 2558 b7317d2fe0e9
parent 1614 3f76cdbceb6e
permissions -rw-r--r--
scripts, cc/gcc: do not fail on existing symlinks or build.log

If the user builds a toolchain over an existing one, so, without removing
CT_PREFIX_DIR, the build fails as the symlinks already exist, as does the
build.log.

This can also happen (for build.log) if the user first ran in download-
or extract-only.

Patch (with no SoB) originally from:
Phil Wilshire <phil.wilshire@overturenetworks.com>

Modified by me as it did not apply cleanly.

Signed-off-by: "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
(transplanted from 1ebc2248cc60230cd53ff94ae8f8f1e3261461a3)
fr@1621
     1
--- binutils/bfd/elf64-ppc.c.jj	2004-09-27 16:46:06.000000000 -0400
fr@1621
     2
+++ binutils/bfd/elf64-ppc.c	2004-10-04 09:09:50.000000000 -0400
yann@1614
     3
@@ -9681,7 +9681,12 @@ ppc64_elf_relocate_section (bfd *output_
yann@1614
     4
 	      else if (!SYMBOL_REFERENCES_LOCAL (info, &h->elf)
yann@1614
     5
 		       && !is_opd
yann@1614
     6
 		       && r_type != R_PPC64_TOC)
yann@1614
     7
-		outrel.r_info = ELF64_R_INFO (h->elf.dynindx, r_type);
yann@1614
     8
+		{
yann@1614
     9
+		  outrel.r_info = ELF64_R_INFO (h->elf.dynindx, r_type);
yann@1614
    10
+		  if (h->elf.dynindx == -1
yann@1614
    11
+		      && h->elf.root.type == bfd_link_hash_undefweak)
yann@1614
    12
+		  memset (&outrel, 0, sizeof outrel);
yann@1614
    13
+		}
yann@1614
    14
 	      else
yann@1614
    15
 		{
yann@1614
    16
 		  /* This symbol is local, or marked to become local,