Blame SOURCES/binutils-2.27-revert-PLT-elision.patch

0b07f1
diff -rup binutils.orig/bfd/elf32-i386.c binutils-2.27/bfd/elf32-i386.c
0b07f1
--- binutils.orig/bfd/elf32-i386.c	2017-05-17 11:22:32.393303573 +0100
0b07f1
+++ binutils-2.27/bfd/elf32-i386.c	2017-05-17 11:25:33.097138811 +0100
0b07f1
@@ -2322,8 +2322,7 @@ do_size:
0b07f1
       if (use_plt_got
0b07f1
 	  && h != NULL
0b07f1
 	  && h->plt.refcount > 0
0b07f1
-	  && (((info->flags & DF_BIND_NOW) && !h->pointer_equality_needed)
0b07f1
-	      || h->got.refcount > 0)
0b07f1
+	  && h->got.refcount > 0
0b07f1
 	  && htab->plt_got == NULL)
0b07f1
 	{
0b07f1
 	  /* Create the GOT procedure linkage table.  */
0b07f1
@@ -2672,16 +2671,6 @@ elf_i386_allocate_dynrelocs (struct elf_
0b07f1
 	 if PLT is used.  */
0b07f1
       eh->func_pointer_refcount = 0;
0b07f1
 
0b07f1
-      if ((info->flags & DF_BIND_NOW) && !h->pointer_equality_needed)
0b07f1
-	{
0b07f1
-	  /* Don't use the regular PLT for DF_BIND_NOW. */
0b07f1
-	  h->plt.offset = (bfd_vma) -1;
0b07f1
-
0b07f1
-	  /* Use the GOT PLT.  */
0b07f1
-	  h->got.refcount = 1;
0b07f1
-	  eh->plt_got.refcount = 1;
0b07f1
-	}
0b07f1
-
0b07f1
       use_plt_got = eh->plt_got.refcount > 0;
0b07f1
 
0b07f1
       /* Make sure this symbol is output as a dynamic symbol.
0b07f1
diff -rup binutils.orig/bfd/elf64-x86-64.c binutils-2.27/bfd/elf64-x86-64.c
0b07f1
--- binutils.orig/bfd/elf64-x86-64.c	2017-05-17 11:22:32.396303537 +0100
0b07f1
+++ binutils-2.27/bfd/elf64-x86-64.c	2017-05-17 11:26:00.250813521 +0100
0b07f1
@@ -2722,8 +2722,7 @@ do_size:
0b07f1
       if (use_plt_got
0b07f1
 	  && h != NULL
0b07f1
 	  && h->plt.refcount > 0
0b07f1
-	  && (((info->flags & DF_BIND_NOW) && !h->pointer_equality_needed)
0b07f1
-	      || h->got.refcount > 0)
0b07f1
+	  && h->got.refcount > 0
0b07f1
 	  && htab->plt_got == NULL)
0b07f1
 	{
0b07f1
 	  /* Create the GOT procedure linkage table.  */
0b07f1
@@ -3094,16 +3093,6 @@ elf_x86_64_allocate_dynrelocs (struct el
0b07f1
 	 if PLT is used.  */
0b07f1
       eh->func_pointer_refcount = 0;
0b07f1
 
0b07f1
-      if ((info->flags & DF_BIND_NOW) && !h->pointer_equality_needed)
0b07f1
-	{
0b07f1
-	  /* Don't use the regular PLT for DF_BIND_NOW. */
0b07f1
-	  h->plt.offset = (bfd_vma) -1;
0b07f1
-
0b07f1
-	  /* Use the GOT PLT.  */
0b07f1
-	  h->got.refcount = 1;
0b07f1
-	  eh->plt_got.refcount = 1;
0b07f1
-	}
0b07f1
-
0b07f1
       use_plt_got = eh->plt_got.refcount > 0;
0b07f1
 
0b07f1
       /* Make sure this symbol is output as a dynamic symbol.
0b07f1
diff -rup binutils.orig/ld/testsuite/ld-i386/pr17689now.rd binutils-2.27/ld/testsuite/ld-i386/pr17689now.rd
0b07f1
--- binutils.orig/ld/testsuite/ld-i386/pr17689now.rd	2017-05-17 11:22:32.677300171 +0100
0b07f1
+++ binutils-2.27/ld/testsuite/ld-i386/pr17689now.rd	2017-05-17 11:39:36.097021963 +0100
0b07f1
@@ -1,4 +1,3 @@
0b07f1
-#failif
0b07f1
 #...
0b07f1
 [0-9a-f ]+R_386_JUMP_SLOT +0+.*
0b07f1
 #...
0b07f1
diff -rup binutils.orig/ld/testsuite/ld-x86-64/pr17689now.rd binutils-2.27/ld/testsuite/ld-x86-64/pr17689now.rd
0b07f1
--- binutils.orig/ld/testsuite/ld-x86-64/pr17689now.rd	2017-05-17 11:22:32.734299489 +0100
0b07f1
+++ binutils-2.27/ld/testsuite/ld-x86-64/pr17689now.rd	2017-05-17 11:39:53.071818174 +0100
0b07f1
@@ -1,4 +1,3 @@
0b07f1
-#failif
0b07f1
 #...
0b07f1
 [0-9a-f ]+R_X86_64_JUMP_SLOT +0+ +.*
0b07f1
 #...