patches/binutils/2.20.1a/100-ppc64-pie.patch
author "Yann E. MORIN" <yann.morin.1998@free.fr>
Mon Feb 25 21:19:31 2013 +0100 (2013-02-25)
changeset 3185 f89f8e6f8766
parent 2088 4f21ba5f8e91
permissions -rw-r--r--
Makefile: fix parrallel (-j) installs

Currently, we would remove previously installed patches before
installing the new ones. Unfortunately, that does not play well
with heavily parallel installs.

Now, we consider it is the responsibility of the user to first
uninstall any previous version before installing a new one.

Reported-by: Markos Chandras <markos.chandras@gmail.com>
Signed-off-by: "Yann E. MORIN" <yann.morin.1998@free.fr>
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,