Blame SOURCES/binutils-plugin-as-needed.patch

a9feee
diff -rup binutils.orig/ld/testsuite/ld-plugin/lto.exp binutils-2.35.1/ld/testsuite/ld-plugin/lto.exp
a9feee
--- binutils.orig/ld/testsuite/ld-plugin/lto.exp	2020-10-09 11:46:13.571665439 +0100
a9feee
+++ binutils-2.35.1/ld/testsuite/ld-plugin/lto.exp	2020-10-09 11:47:59.113302758 +0100
a9feee
@@ -319,27 +319,6 @@ set lto_link_elf_tests [list \
a9feee
   [list "PR ld/13244" \
a9feee
    "-shared -O2 -fPIC -flto -fuse-linker-plugin -nostdlib" "-O2 -fno-early-inlining -flto" \
a9feee
    {pr13244.c} {{"readelf" {-s --wide} "pr13244.d"}} "pr13244.so" "c"] \
a9feee
-  [list "Build libpr15146a.a" \
a9feee
-   "$plug_opt" "-flto -O2" \
a9feee
-   {pr15146a.c} {} "lib15146a.a"] \
a9feee
-  [list "Build pr15146b.so" \
a9feee
-   "-shared" "-O2 -fpic" \
a9feee
-   {pr15146b.c} {} "pr15146b.so" "c"] \
a9feee
-  [list "Build pr15146c.so" \
a9feee
-   "-shared -Wl,--no-as-needed tmpdir/pr15146b.so" "-O2 -fpic" \
a9feee
-   {pr15146c.c} {} "pr15146c.so" "c"] \
a9feee
-  [list "PR ld/15146 (1)" \
a9feee
-   "-O2 -flto -fuse-linker-plugin -Wl,-rpath-link,. -Wl,--no-copy-dt-needed-entries -Wl,--no-as-needed tmpdir/pr15146a.o tmpdir/pr15146c.so" "" \
a9feee
-   {dummy.c} {{"readelf" {-d} "pr15146.d"}} "pr15146a.exe"] \
a9feee
-  [list "Build libpr15146d.a" \
a9feee
-   "$plug_opt" "-flto -O2" \
a9feee
-   {pr15146d.c} {} "lib15146d.a"] \
a9feee
-  [list "Build libpr16746a.a" \
a9feee
-   "" "" \
a9feee
-   {pr16746a.c pr16746b.c} {} "lib15146a.a"] \
a9feee
-  [list "Build libpr16746b.a" \
a9feee
-   "$plug_opt" "-O2 -flto" \
a9feee
-   {pr16746c.c pr16746d.c} {} "lib15146b.a"] \
a9feee
   [list "PR ld/16746 (1)" \
a9feee
    "-O2 -flto -fuse-linker-plugin tmpdir/pr16746a.o tmpdir/pr16746c.o" "-O2 -flto" \
a9feee
    {dummy.c} {} "pr16746a.exe"] \
a9feee
@@ -602,13 +581,6 @@ run_cc_link_tests $lto_compile_elf_tests
a9feee
 # Restrict these to ELF targets that support shared libs and PIC.
a9feee
 if { [is_elf_format] && [check_lto_shared_available] } {
a9feee
     run_cc_link_tests $lto_link_elf_tests
a9feee
-    set testname "PR ld/15146 (2)"
a9feee
-    set exec_output [run_host_cmd "$CC" "-O2 -flto -fuse-linker-plugin -Wl,-rpath-link,. -Wl,--no-copy-dt-needed-entries -Wl,--no-as-needed tmpdir/pr15146d.o tmpdir/pr15146c.so"]
a9feee
-    if { [ regexp "undefined reference to symbol '\\.?xxx'" $exec_output ] } {
a9feee
-	pass $testname
a9feee
-    } {
a9feee
-	fail $testname
a9feee
-    }
a9feee
     set testname "PR ld/16746 (3)"
a9feee
     set exec_output [run_host_cmd "$CC" "-O2 -flto -fuse-linker-plugin tmpdir/pr16746b.o tmpdir/pr16746d.o"]
a9feee
     if { [ regexp "warning: \\.?foobar" $exec_output ] && ![ regexp "symbol from plugin" $exec_output ] } {
a9feee
a9feee
diff -rup binutils.orig/bfd/elflink.c binutils-2.35.1/bfd/elflink.c
a9feee
--- binutils.orig/bfd/elflink.c	2020-10-09 11:46:14.151663446 +0100
a9feee
+++ binutils-2.35.1/bfd/elflink.c	2020-10-09 11:46:27.222618528 +0100
a9feee
@@ -4970,11 +4970,7 @@ elf_link_add_object_symbols (bfd *abfd,
a9feee
 	     object and a shared object.  */
a9feee
 	  bfd_boolean dynsym = FALSE;
a9feee
 
a9feee
-	  /* Plugin symbols aren't normal.  Don't set def_regular or
a9feee
-	     ref_regular for them, or make them dynamic.  */
a9feee
-	  if ((abfd->flags & BFD_PLUGIN) != 0)
a9feee
-	    ;
a9feee
-	  else if (! dynamic)
a9feee
+	  if (! dynamic)
a9feee
 	    {
a9feee
 	      if (! definition)
a9feee
 		{
a9feee
@@ -5155,10 +5151,6 @@ elf_link_add_object_symbols (bfd *abfd,
a9feee
 	      && !bfd_link_relocatable (info))
a9feee
 	    dynsym = FALSE;
a9feee
 
a9feee
-	  /* Nor should we make plugin symbols dynamic.  */
a9feee
-	  if ((abfd->flags & BFD_PLUGIN) != 0)
a9feee
-	    dynsym = FALSE;
a9feee
-
a9feee
 	  if (definition)
a9feee
 	    {
a9feee
 	      h->target_internal = isym->st_target_internal;
a9feee
@@ -5185,7 +5177,7 @@ elf_link_add_object_symbols (bfd *abfd,
a9feee
 		}
a9feee
 	    }
a9feee
 
a9feee
-	  if (dynsym && h->dynindx == -1)
a9feee
+	  if (dynsym && (abfd->flags & BFD_PLUGIN) == 0 && h->dynindx == -1)
a9feee
 	    {
a9feee
 	      if (! bfd_elf_link_record_dynamic_symbol (info, h))
a9feee
 		goto error_free_vers;
a9feee
a9feee
--- binutils.orig/ld/testsuite/ld-plugin/lto.exp	2020-10-28 12:23:49.034685727 +0000
a9feee
+++ binutils-2.30/ld/testsuite/ld-plugin/lto.exp	2020-10-28 12:24:48.288484833 +0000
a9feee
@@ -265,12 +265,6 @@ set lto_link_elf_tests [list \
a9feee
   [list "PR ld/13244" \
a9feee
    "-shared -O2 -fPIC -flto -fuse-linker-plugin -nostdlib" "-O2 -fno-early-inlining -flto" \
a9feee
    {pr13244.c} {{"readelf" {-s --wide} "pr13244.d"}} "pr13244.so" "c"] \
a9feee
-  [list "PR ld/16746 (1)" \
a9feee
-   "-O2 -flto -fuse-linker-plugin tmpdir/pr16746a.o tmpdir/pr16746c.o" "-O2 -flto" \
a9feee
-   {dummy.c} {} "pr16746a.exe"] \
a9feee
-  [list "PR ld/16746 (2)" \
a9feee
-   "-O2 -flto -fuse-linker-plugin tmpdir/pr16746c.o tmpdir/pr16746a.o" "-O2 -flto" \
a9feee
-   {dummy.c} {} "pr16746b.exe"] \
a9feee
   [list "Build pr21382a.o" \
a9feee
    "" "-O2 -flto" \
a9feee
    {pr21382a.c} {} "" "c"] \
a9feee
@@ -424,25 +418,6 @@ run_cc_link_tests $lto_link_tests
a9feee
 # by some elf tests besides shared libs tests.  So, always compile them.
a9feee
 run_cc_link_tests $lto_compile_elf_tests
a9feee
 
a9feee
-# Restrict these to ELF targets that support shared libs and PIC.
a9feee
-if { [is_elf_format] && [check_lto_shared_available] } {
a9feee
-    run_cc_link_tests $lto_link_elf_tests
a9feee
-    set testname "PR ld/16746 (3)"
a9feee
-    set exec_output [run_host_cmd "$CC" "-O2 -flto -fuse-linker-plugin tmpdir/pr16746b.o tmpdir/pr16746d.o"]
a9feee
-    if { [ regexp "warning: \\.?foobar" $exec_output ] && ![ regexp "symbol from plugin" $exec_output ] } {
a9feee
-	pass $testname
a9feee
-    } {
a9feee
-	fail $testname
a9feee
-    }
a9feee
-    set testname "PR ld/16746 (4)"
a9feee
-    set exec_output [run_host_cmd "$CC" "-O2 -flto -fuse-linker-plugin tmpdir/pr16746d.o tmpdir/pr16746b.o"]
a9feee
-    if { [ regexp "warning: \\.?foobar" $exec_output ] && ![ regexp "symbol from plugin" $exec_output ] } {
a9feee
-	pass $testname
a9feee
-    } {
a9feee
-	fail $testname
a9feee
-    }
a9feee
-}
a9feee
-
a9feee
 set testname "Build liblto-11.a"
a9feee
 remote_file host delete "tmpdir/liblto-11.a"
a9feee
 set catch_output [run_host_cmd "$ar" "rc $plug_opt tmpdir/liblto-11.a tmpdir/lto-11a.o tmpdir/lto-11b.o tmpdir/lto-11c.o"]
a9feee
--- binutils.orig/ld/testsuite/ld-plugin/lto.exp	2020-10-28 12:47:18.581911539 +0000
a9feee
+++ binutils-2.30/ld/testsuite/ld-plugin/lto.exp	2020-10-28 12:50:25.048280769 +0000
a9feee
@@ -418,6 +418,11 @@ run_cc_link_tests $lto_link_tests
a9feee
 # by some elf tests besides shared libs tests.  So, always compile them.
a9feee
 run_cc_link_tests $lto_compile_elf_tests
a9feee
 
a9feee
+# Restrict these to ELF targets that support shared libs and PIC.
a9feee
+if { [is_elf_format] && [check_lto_shared_available] } {
a9feee
+    run_cc_link_tests $lto_link_elf_tests
a9feee
+}
a9feee
+
a9feee
 set testname "Build liblto-11.a"
a9feee
 remote_file host delete "tmpdir/liblto-11.a"
a9feee
 set catch_output [run_host_cmd "$ar" "rc $plug_opt tmpdir/liblto-11.a tmpdir/lto-11a.o tmpdir/lto-11b.o tmpdir/lto-11c.o"]