patches/binutils/2.20.1/100-ppc64-pie.patch
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Fri Apr 15 00:22:42 2011 +0200 (2011-04-15)
branch1.11
changeset 2557 b71761e8cff1
parent 1621 60446d2e5660
permissions -rw-r--r--
scripts/internals: do not remove lib{32,64}/ symlinks after build

During the build, we create lib{32,64}/ symlinks out of the sysroot.
In some cases (eg. mingw32 target), these symlinks are still required
when running the toolchain. For other combinations, the symlinks are
without incidence, so they can be safely kept after the build.

Signed-off-by: "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
(transplanted from 751c3f735ada4a95aa981841b832adb08b88ce27)
yann@2088
     1
yann@2088
     2
yann@2088
     3
diff -durN binutils-2.20.1.orig/bfd/elf64-ppc.c binutils-2.20.1/bfd/elf64-ppc.c
yann@2088
     4
--- binutils-2.20.1.orig/bfd/elf64-ppc.c	2010-02-03 14:28:25.000000000 +0100
yann@2088
     5
+++ binutils-2.20.1/bfd/elf64-ppc.c	2010-08-17 19:32:04.000000000 +0200
yann@2088
     6
@@ -11991,7 +11991,12 @@
yann@1614
     7
 	      else if (!SYMBOL_REFERENCES_LOCAL (info, &h->elf)
yann@1614
     8
 		       && !is_opd
yann@1614
     9
 		       && r_type != R_PPC64_TOC)
yann@1614
    10
-		outrel.r_info = ELF64_R_INFO (h->elf.dynindx, r_type);
yann@1614
    11
+		{
yann@1614
    12
+		  outrel.r_info = ELF64_R_INFO (h->elf.dynindx, r_type);
yann@1614
    13
+		  if (h->elf.dynindx == -1
yann@1614
    14
+		      && h->elf.root.type == bfd_link_hash_undefweak)
yann@1614
    15
+		  memset (&outrel, 0, sizeof outrel);
yann@1614
    16
+		}
yann@1614
    17
 	      else
yann@1614
    18
 		{
yann@1614
    19
 		  /* This symbol is local, or marked to become local,