Nick Clifton 92298b
diff -rup binutils.orig/bfd/elf32-i386.c binutils-2.30/bfd/elf32-i386.c
Nick Clifton 92298b
--- binutils.orig/bfd/elf32-i386.c	2018-03-09 14:43:05.324208873 +0000
Nick Clifton 92298b
+++ binutils-2.30/bfd/elf32-i386.c	2018-03-09 14:43:23.158000456 +0000
Nick Clifton 92298b
@@ -2202,12 +2202,19 @@ elf_i386_relocate_section (bfd *output_b
Nick Clifton 92298b
 
Nick Clifton 92298b
 	  if ((input_section->flags & SEC_ALLOC) == 0)
Nick Clifton 92298b
 	    {
Nick Clifton 92298b
+	      /* If this is a SHT_NOTE section without SHF_ALLOC, treat
Nick Clifton 92298b
+	         STT_GNU_IFUNC symbol as STT_FUNC.  */
Nick Clifton 92298b
+	      if (elf_section_type (input_section) == SHT_NOTE)
Nick Clifton 92298b
+		goto skip_ifunc;
Nick Clifton 92298b
 	      /* Dynamic relocs are not propagated for SEC_DEBUGGING
Nick Clifton 92298b
 		 sections because such sections are not SEC_ALLOC and
Nick Clifton 92298b
 		 thus ld.so will not process them.  */
Nick Clifton 92298b
 	      if ((input_section->flags & SEC_DEBUGGING) != 0)
Nick Clifton 92298b
 		continue;
Nick Clifton 92298b
-	      abort ();
Nick Clifton 92298b
+	      _bfd_error_handler (_("%B: error: relocation againt ifunc symbol in non-alloc section %A"),
Nick Clifton 92298b
+				  input_bfd, input_section);
Nick Clifton 92298b
+	      bfd_set_error (bfd_error_invalid_operation);
Nick Clifton 92298b
+	      return FALSE;
Nick Clifton 92298b
 	    }
Nick Clifton 92298b
 
Nick Clifton 92298b
 	  /* STT_GNU_IFUNC symbol must go through PLT.  */
Nick Clifton 92298b
@@ -2421,6 +2428,7 @@ do_ifunc_pointer:
Nick Clifton 92298b
 	    }
Nick Clifton 92298b
 	}
Nick Clifton 92298b
 
Nick Clifton 92298b
+    skip_ifunc:
Nick Clifton 92298b
       resolved_to_zero = (eh != NULL
Nick Clifton 92298b
 			  && UNDEFINED_WEAK_RESOLVED_TO_ZERO (info, eh));
Nick Clifton 92298b
 
Nick Clifton 92298b
diff -rup binutils.orig/bfd/elf32-s390.c binutils-2.30/bfd/elf32-s390.c
Nick Clifton 92298b
--- binutils.orig/bfd/elf32-s390.c	2018-03-09 14:43:05.325208861 +0000
Nick Clifton 92298b
+++ binutils-2.30/bfd/elf32-s390.c	2018-03-09 14:43:31.353904647 +0000
Nick Clifton 92298b
@@ -2601,6 +2601,9 @@ elf_s390_relocate_section (bfd *output_b
Nick Clifton 92298b
 	case R_390_8:
Nick Clifton 92298b
 	case R_390_16:
Nick Clifton 92298b
 	case R_390_32:
Nick Clifton 92298b
+	  if ((input_section->flags & SEC_ALLOC) == 0)
Nick Clifton 92298b
+	    break;
Nick Clifton 92298b
+
Nick Clifton 92298b
 	  if (h != NULL
Nick Clifton 92298b
 	      && s390_is_ifunc_symbol_p (h)
Nick Clifton 92298b
 	      && h->def_regular)
Nick Clifton 92298b
@@ -2662,9 +2665,6 @@ elf_s390_relocate_section (bfd *output_b
Nick Clifton 92298b
 		}
Nick Clifton 92298b
 	    }
Nick Clifton 92298b
 
Nick Clifton 92298b
-	  if ((input_section->flags & SEC_ALLOC) == 0)
Nick Clifton 92298b
-	    break;
Nick Clifton 92298b
-
Nick Clifton 92298b
 	  if ((bfd_link_pic (info)
Nick Clifton 92298b
 	       && (h == NULL
Nick Clifton 92298b
 		   || (ELF_ST_VISIBILITY (h->other) == STV_DEFAULT
Nick Clifton 92298b
Only in binutils-2.30/bfd: elf32-s390.c.orig
Nick Clifton 92298b
diff -rup binutils.orig/bfd/elf64-s390.c binutils-2.30/bfd/elf64-s390.c
Nick Clifton 92298b
--- binutils.orig/bfd/elf64-s390.c	2018-03-09 14:43:05.341208674 +0000
Nick Clifton 92298b
+++ binutils-2.30/bfd/elf64-s390.c	2018-03-09 14:43:31.354904635 +0000
Nick Clifton 92298b
@@ -2559,6 +2559,9 @@ elf_s390_relocate_section (bfd *output_b
Nick Clifton 92298b
 	case R_390_32:
Nick Clifton 92298b
 	case R_390_64:
Nick Clifton 92298b
 
Nick Clifton 92298b
+	  if ((input_section->flags & SEC_ALLOC) == 0)
Nick Clifton 92298b
+	    break;
Nick Clifton 92298b
+
Nick Clifton 92298b
 	  if (h != NULL
Nick Clifton 92298b
 	      && s390_is_ifunc_symbol_p (h)
Nick Clifton 92298b
 	      && h->def_regular)
Nick Clifton 92298b
@@ -2621,9 +2624,6 @@ elf_s390_relocate_section (bfd *output_b
Nick Clifton 92298b
 		}
Nick Clifton 92298b
 	    }
Nick Clifton 92298b
 
Nick Clifton 92298b
-	  if ((input_section->flags & SEC_ALLOC) == 0)
Nick Clifton 92298b
-	    break;
Nick Clifton 92298b
-
Nick Clifton 92298b
 	  if ((bfd_link_pic (info)
Nick Clifton 92298b
 	       && (h == NULL
Nick Clifton 92298b
 		   || (ELF_ST_VISIBILITY (h->other) == STV_DEFAULT
Nick Clifton 92298b
Only in binutils-2.30/bfd: elf64-s390.c.orig
Nick Clifton 92298b
diff -rup binutils.orig/bfd/elf64-x86-64.c binutils-2.30/bfd/elf64-x86-64.c
Nick Clifton 92298b
--- binutils.orig/bfd/elf64-x86-64.c	2018-03-09 14:43:05.344208639 +0000
Nick Clifton 92298b
+++ binutils-2.30/bfd/elf64-x86-64.c	2018-03-09 14:43:23.161000420 +0000
Nick Clifton 92298b
@@ -2499,12 +2499,19 @@ elf_x86_64_relocate_section (bfd *output
Nick Clifton 92298b
 
Nick Clifton 92298b
 	  if ((input_section->flags & SEC_ALLOC) == 0)
Nick Clifton 92298b
 	    {
Nick Clifton 92298b
+	      /* If this is a SHT_NOTE section without SHF_ALLOC, treat
Nick Clifton 92298b
+	         STT_GNU_IFUNC symbol as STT_FUNC.  */
Nick Clifton 92298b
+	      if (elf_section_type (input_section) == SHT_NOTE)
Nick Clifton 92298b
+		goto skip_ifunc;
Nick Clifton 92298b
 	      /* Dynamic relocs are not propagated for SEC_DEBUGGING
Nick Clifton 92298b
 		 sections because such sections are not SEC_ALLOC and
Nick Clifton 92298b
 		 thus ld.so will not process them.  */
Nick Clifton 92298b
 	      if ((input_section->flags & SEC_DEBUGGING) != 0)
Nick Clifton 92298b
 		continue;
Nick Clifton 92298b
-	      abort ();
Nick Clifton 92298b
+	      _bfd_error_handler (_("%B: error: relocation againt ifunc symbol in non-alloc section %A"),
Nick Clifton 92298b
+				  input_bfd, input_section);
Nick Clifton 92298b
+	      bfd_set_error (bfd_error_invalid_operation);
Nick Clifton 92298b
+	      return FALSE;
Nick Clifton 92298b
 	    }
Nick Clifton 92298b
 
Nick Clifton 92298b
 	  switch (r_type)
Nick Clifton 92298b
@@ -2722,6 +2729,7 @@ do_ifunc_pointer:
Nick Clifton 92298b
 	    }
Nick Clifton 92298b
 	}
Nick Clifton 92298b
 
Nick Clifton 92298b
+    skip_ifunc:
Nick Clifton 92298b
       resolved_to_zero = (eh != NULL
Nick Clifton 92298b
 			  && UNDEFINED_WEAK_RESOLVED_TO_ZERO (info, eh));
Nick Clifton 92298b
 
Nick Clifton 92298b
diff -rup binutils.orig/bfd/elfnn-aarch64.c binutils-2.30/bfd/elfnn-aarch64.c
Nick Clifton 92298b
--- binutils.orig/bfd/elfnn-aarch64.c	2018-03-09 14:43:05.337208721 +0000
Nick Clifton 92298b
+++ binutils-2.30/bfd/elfnn-aarch64.c	2018-03-09 14:43:31.355904624 +0000
Nick Clifton 92298b
@@ -4987,6 +4987,11 @@ elfNN_aarch64_final_link_relocate (reloc
Nick Clifton 92298b
 
Nick Clifton 92298b
       if ((input_section->flags & SEC_ALLOC) == 0)
Nick Clifton 92298b
 	{
Nick Clifton 92298b
+	  /* If this is a SHT_NOTE section without SHF_ALLOC, treat
Nick Clifton 92298b
+	     STT_GNU_IFUNC symbol as STT_FUNC.  */
Nick Clifton 92298b
+	  if (elf_section_type (input_section) == SHT_NOTE)
Nick Clifton 92298b
+	    goto skip_ifunc;
Nick Clifton 92298b
+
Nick Clifton 92298b
 	  /* Dynamic relocs are not propagated for SEC_DEBUGGING
Nick Clifton 92298b
 	     sections because such sections are not SEC_ALLOC and
Nick Clifton 92298b
 	     thus ld.so will not process them.  */
Nick Clifton 92298b
@@ -5180,6 +5185,7 @@ bad_ifunc_reloc:
Nick Clifton 92298b
 	}
Nick Clifton 92298b
     }
Nick Clifton 92298b
 
Nick Clifton 92298b
+ skip_ifunc:
Nick Clifton 92298b
   resolved_to_zero = (h != NULL
Nick Clifton 92298b
 		      && UNDEFWEAK_NO_DYNAMIC_RELOC (info, h));
Nick Clifton 92298b
 
Nick Clifton 92298b
Only in binutils-2.30/bfd: elfnn-aarch64.c.orig
Nick Clifton 92298b
diff -rup binutils.orig/bfd/elfxx-sparc.c binutils-2.30/bfd/elfxx-sparc.c
Nick Clifton 92298b
--- binutils.orig/bfd/elfxx-sparc.c	2018-03-09 14:43:05.333208768 +0000
Nick Clifton 92298b
+++ binutils-2.30/bfd/elfxx-sparc.c	2018-03-09 14:43:31.355904624 +0000
Nick Clifton 92298b
@@ -3026,7 +3026,13 @@ _bfd_sparc_elf_relocate_section (bfd *ou
Nick Clifton 92298b
 
Nick Clifton 92298b
 	  if ((input_section->flags & SEC_ALLOC) == 0
Nick Clifton 92298b
 	      || h->plt.offset == (bfd_vma) -1)
Nick Clifton 92298b
-	    abort ();
Nick Clifton 92298b
+	    {
Nick Clifton 92298b
+	      /* If this is a SHT_NOTE section without SHF_ALLOC, treat
Nick Clifton 92298b
+	         STT_GNU_IFUNC symbol as STT_FUNC.  */
Nick Clifton 92298b
+	      if (elf_section_type (input_section) == SHT_NOTE)
Nick Clifton 92298b
+		goto skip_ifunc;
Nick Clifton 92298b
+	      abort ();
Nick Clifton 92298b
+	    }
Nick Clifton 92298b
 
Nick Clifton 92298b
 	  plt_sec = htab->elf.splt;
Nick Clifton 92298b
 	  if (! plt_sec)
Nick Clifton 92298b
@@ -3130,6 +3136,7 @@ _bfd_sparc_elf_relocate_section (bfd *ou
Nick Clifton 92298b
 	    }
Nick Clifton 92298b
 	}
Nick Clifton 92298b
 
Nick Clifton 92298b
+    skip_ifunc:
Nick Clifton 92298b
       eh = (struct _bfd_sparc_elf_link_hash_entry *) h;
Nick Clifton 92298b
       resolved_to_zero = (eh != NULL
Nick Clifton 92298b
 			  && UNDEFINED_WEAK_RESOLVED_TO_ZERO (info, eh));
Nick Clifton 92298b
Only in binutils-2.30/bfd: elfxx-sparc.c.orig
Nick Clifton 92298b
diff -rup binutils.orig/ld/testsuite/ld-ifunc/ifunc.exp binutils-2.30/ld/testsuite/ld-ifunc/ifunc.exp
Nick Clifton 92298b
--- binutils.orig/ld/testsuite/ld-ifunc/ifunc.exp	2018-03-09 14:43:04.844214486 +0000
Nick Clifton 92298b
+++ binutils-2.30/ld/testsuite/ld-ifunc/ifunc.exp	2018-03-09 14:43:31.355904624 +0000
Nick Clifton 92298b
@@ -47,6 +47,9 @@ if ![check_shared_lib_support] {
Nick Clifton 92298b
     return
Nick Clifton 92298b
 }
Nick Clifton 92298b
 
Nick Clifton 92298b
+# This test does not need a compiler...
Nick Clifton 92298b
+run_dump_test "ifuncmod5"
Nick Clifton 92298b
+
Nick Clifton 92298b
 # We need a working compiler.  (Strictly speaking this is
Nick Clifton 92298b
 # not true, we could use target specific assembler files).
Nick Clifton 92298b
 if { [which $CC] == 0 } {
Nick Clifton 92298b
Only in binutils-2.30: testsuite
Nick Clifton 92298b
--- /dev/null	2018-03-09 07:59:09.608015200 +0000
Nick Clifton 92298b
+++ binutils-2.30/ld/testsuite/ld-ifunc/ifuncmod5.s	2018-03-09 14:45:45.698334500 +0000
Nick Clifton 92298b
@@ -0,0 +1,105 @@
Nick Clifton 92298b
+	.file	"ifuncmod5.c"
Nick Clifton 92298b
+
Nick Clifton 92298b
+	.text
Nick Clifton 92298b
+	.type ifuncmod5.c, STT_NOTYPE
Nick Clifton 92298b
+ifuncmod5.c:
Nick Clifton 92298b
+	.size ifuncmod5.c, 0
Nick Clifton 92298b
+
Nick Clifton 92298b
+	.pushsection .gnu.build.attributes, "", %note
Nick Clifton 92298b
+	.balign 4
Nick Clifton 92298b
+	.dc.l 8 	
Nick Clifton 92298b
+	.dc.l 16	
Nick Clifton 92298b
+	.dc.l 0x100	
Nick Clifton 92298b
+	.asciz "GA$?3p4"	
Nick Clifton 92298b
+	.dc.a ifuncmod5.c
Nick Clifton 92298b
+	.dc.a ifuncmod5.c_end	
Nick Clifton 92298b
+	.popsection
Nick Clifton 92298b
+
Nick Clifton 92298b
+.Ltext0:
Nick Clifton 92298b
+#APP
Nick Clifton 92298b
+	.protected global
Nick Clifton 92298b
+	.type foo, %gnu_indirect_function
Nick Clifton 92298b
+	.type foo_hidden, %gnu_indirect_function
Nick Clifton 92298b
+	.type foo_protected, %gnu_indirect_function
Nick Clifton 92298b
+	.hidden foo_hidden
Nick Clifton 92298b
+	.protected foo_protected
Nick Clifton 92298b
+#NO_APP
Nick Clifton 92298b
+	.align	8
Nick Clifton 92298b
+	.type	one, %function
Nick Clifton 92298b
+one:
Nick Clifton 92298b
+	.dc.l 0
Nick Clifton 92298b
+	.size	one, .-one
Nick Clifton 92298b
+	.align	8
Nick Clifton 92298b
+
Nick Clifton 92298b
+.globl foo
Nick Clifton 92298b
+	.type	foo, %function
Nick Clifton 92298b
+foo:
Nick Clifton 92298b
+	.dc.l	0
Nick Clifton 92298b
+	.size	foo, .-foo
Nick Clifton 92298b
+
Nick Clifton 92298b
+	.pushsection .gnu.build.attributes
Nick Clifton 92298b
+	.dc.l 6		
Nick Clifton 92298b
+	.dc.l 16	
Nick Clifton 92298b
+	.dc.l 0x101	
Nick Clifton 92298b
+	.dc.b 0x47, 0x41, 0x2a, 0x2, 0, 0 	
Nick Clifton 92298b
+	.dc.b 0, 0 	
Nick Clifton 92298b
+	.dc.a foo
Nick Clifton 92298b
+	.dc.a foo_end	
Nick Clifton 92298b
+	.popsection
Nick Clifton 92298b
+
Nick Clifton 92298b
+foo_end:
Nick Clifton 92298b
+	.align	8
Nick Clifton 92298b
+.globl foo_hidden
Nick Clifton 92298b
+	.type	foo_hidden, %function
Nick Clifton 92298b
+foo_hidden:
Nick Clifton 92298b
+	.dc.l	0
Nick Clifton 92298b
+	.size	foo_hidden, .-foo_hidden
Nick Clifton 92298b
+
Nick Clifton 92298b
+	.pushsection .gnu.build.attributes
Nick Clifton 92298b
+	.dc.l 6		
Nick Clifton 92298b
+	.dc.l 16	
Nick Clifton 92298b
+	.dc.l 0x101	
Nick Clifton 92298b
+	.dc.b 0x47, 0x41, 0x2a, 0x2, 0, 0 	
Nick Clifton 92298b
+	.dc.b 0, 0 	
Nick Clifton 92298b
+	.dc.a foo_hidden
Nick Clifton 92298b
+	.dc.a foo_hidden_end	
Nick Clifton 92298b
+	.popsection
Nick Clifton 92298b
+
Nick Clifton 92298b
+foo_hidden_end:
Nick Clifton 92298b
+	.align	8
Nick Clifton 92298b
+
Nick Clifton 92298b
+	.globl foo_protected
Nick Clifton 92298b
+	.type	foo_protected, %function
Nick Clifton 92298b
+foo_protected:
Nick Clifton 92298b
+	.dc.l	0
Nick Clifton 92298b
+
Nick Clifton 92298b
+	.size	foo_protected, .-foo_protected
Nick Clifton 92298b
+
Nick Clifton 92298b
+	.pushsection .gnu.build.attributes
Nick Clifton 92298b
+	.dc.l 6		
Nick Clifton 92298b
+	.dc.l 16	
Nick Clifton 92298b
+	.dc.l 0x101	
Nick Clifton 92298b
+	.dc.b 0x47, 0x41, 0x2a, 0x2, 0, 0 	
Nick Clifton 92298b
+	.dc.b 0, 0 	
Nick Clifton 92298b
+	.dc.a foo_protected
Nick Clifton 92298b
+	.dc.a foo_protected_end	
Nick Clifton 92298b
+	.popsection
Nick Clifton 92298b
+
Nick Clifton 92298b
+foo_protected_end:
Nick Clifton 92298b
+	.globl global
Nick Clifton 92298b
+
Nick Clifton 92298b
+	.data
Nick Clifton 92298b
+	.align	4
Nick Clifton 92298b
+	.type	global, %object
Nick Clifton 92298b
+	.size	global, 4
Nick Clifton 92298b
+global:
Nick Clifton 92298b
+	.long	-1
Nick Clifton 92298b
+
Nick Clifton 92298b
+	.text
Nick Clifton 92298b
+	.Letext0:
Nick Clifton 92298b
+
Nick Clifton 92298b
+ifuncmod5.c_end:
Nick Clifton 92298b
+	.type ifuncmod5.c_end, STT_NOTYPE
Nick Clifton 92298b
+	.size ifuncmod5.c_end, 0
Nick Clifton 92298b
+
Nick Clifton 92298b
+
Nick Clifton 92298b
--- /dev/null	2018-03-09 07:59:09.608015200 +0000
Nick Clifton 92298b
+++ binutils-2.30/ld/testsuite/ld-ifunc/ifuncmod5.d	2018-03-09 14:45:45.698334500 +0000
Nick Clifton 92298b
@@ -0,0 +1,8 @@
Nick Clifton 92298b
+# name: Reloc against IFUNC symbol in NOTE section
Nick Clifton 92298b
+# ld: -shared
Nick Clifton 92298b
+# nm: -p
Nick Clifton 92298b
+
Nick Clifton 92298b
+# We do not actually care about the notes at the moment.
Nick Clifton 92298b
+# The purpose of this test is to make sure that the link completes successfully.
Nick Clifton 92298b
+#pass
Nick Clifton 92298b
+