[arch-commits] Commit in binutils/trunk (2 files)
Frederik Schwan
freswa at gemini.archlinux.org
Mon Feb 14 10:43:52 UTC 2022
Date: Monday, February 14, 2022 @ 10:43:52
Author: freswa
Revision: 437182
fix incorrect undefined symbol issue
https://sourceware.org/bugzilla/show_bug.cgi?id=28879
Added:
binutils/trunk/fix-incorrect-undefined-symbol.patch
Modified:
binutils/trunk/PKGBUILD
--------------------------------------+
PKGBUILD | 10 ++
fix-incorrect-undefined-symbol.patch | 114 +++++++++++++++++++++++++++++++++
2 files changed, 122 insertions(+), 2 deletions(-)
Modified: PKGBUILD
===================================================================
--- PKGBUILD 2022-02-13 23:54:58 UTC (rev 437181)
+++ PKGBUILD 2022-02-14 10:43:52 UTC (rev 437182)
@@ -19,9 +19,11 @@
options=(staticlibs !distcc !ccache debug)
#_commit=cb5f6a3e146cc70bc2d864989386df80acec5d3e
#source=(git+https://sourceware.org/git/binutils-gdb.git#commit=$_commit)
-source=(https://ftp.gnu.org/gnu/binutils/binutils-$pkgver.tar.xz{,.sig})
+source=(https://ftp.gnu.org/gnu/binutils/binutils-$pkgver.tar.xz{,.sig}
+ fix-incorrect-undefined-symbol.patch)
sha256sums=('e316477a914f567eccc34d5d29785b8b0f5a10208d36bbacedcc39048ecfe024'
- 'SKIP')
+ 'SKIP'
+ 'fd33b2f8cac7561cecf3fdbb5a50fd2f2dfa6420516cbe57c47784a06fa16bf6')
validpgpkeys=(3A24BC1E8FB409FA9F14371813FCEF89DD9E3C4F)
prepare() {
@@ -35,6 +37,10 @@
# hack! - libiberty configure tests for header files using "$CPP $CPPFLAGS"
sed -i "/ac_cpp=/s/\$CPPFLAGS/\$CPPFLAGS -O2/" libiberty/configure
+
+ # fix incorrect "undefined reference" errors
+ # https://sourceware.org/bugzilla/show_bug.cgi?id=28879
+ patch -Np1 -i "${srcdir}"/fix-incorrect-undefined-symbol.patch
}
build() {
Added: fix-incorrect-undefined-symbol.patch
===================================================================
--- fix-incorrect-undefined-symbol.patch (rev 0)
+++ fix-incorrect-undefined-symbol.patch 2022-02-14 10:43:52 UTC (rev 437182)
@@ -0,0 +1,114 @@
+From 20ea3acc727f3be6322dfbd881e506873535231d Mon Sep 17 00:00:00 2001
+From: "H.J. Lu" <hjl.tools at gmail.com>
+Date: Fri, 11 Feb 2022 15:13:19 -0800
+Subject: [PATCH] ld: Keep indirect symbol from IR if referenced from shared
+ object
+
+Don't change indirect symbol defined in IR to undefined if it is
+referenced from shared object.
+
+bfd/
+
+ PR ld/28879
+ * elflink.c (_bfd_elf_merge_symbol): Don't change indirect
+ symbol defined in IR to undefined if it is referenced from
+ shared object.
+
+ld/
+
+ PR ld/28879
+ * testsuite/ld-plugin/lto.exp: Run PR ld/28879 tests.
+ * testsuite/ld-plugin/pr28879a.cc: New file.
+ * testsuite/ld-plugin/pr28879b.cc: Likewise.
+---
+ bfd/elflink.c | 5 ++---
+ ld/testsuite/ld-plugin/lto.exp | 26 ++++++++++++++++++++++++++
+ ld/testsuite/ld-plugin/pr28879a.cc | 7 +++++++
+ ld/testsuite/ld-plugin/pr28879b.cc | 8 ++++++++
+ 4 files changed, 43 insertions(+), 3 deletions(-)
+ create mode 100644 ld/testsuite/ld-plugin/pr28879a.cc
+ create mode 100644 ld/testsuite/ld-plugin/pr28879b.cc
+
+diff --git a/bfd/elflink.c b/bfd/elflink.c
+index 6fa18d92007..f8521426cad 100644
+--- a/bfd/elflink.c
++++ b/bfd/elflink.c
+@@ -1294,9 +1294,8 @@ _bfd_elf_merge_symbol (bfd *abfd,
+ h->root.non_ir_ref_dynamic = true;
+ hi->root.non_ir_ref_dynamic = true;
+ }
+-
+- if ((oldbfd->flags & BFD_PLUGIN) != 0
+- && hi->root.type == bfd_link_hash_indirect)
++ else if ((oldbfd->flags & BFD_PLUGIN) != 0
++ && hi->root.type == bfd_link_hash_indirect)
+ {
+ /* Change indirect symbol from IR to undefined. */
+ hi->root.type = bfd_link_hash_undefined;
+diff --git a/ld/testsuite/ld-plugin/lto.exp b/ld/testsuite/ld-plugin/lto.exp
+index a70a84562b8..64b880265ee 100644
+--- a/ld/testsuite/ld-plugin/lto.exp
++++ b/ld/testsuite/ld-plugin/lto.exp
+@@ -471,6 +471,32 @@ set lto_link_elf_tests [list \
+ [list {pr27441c.so} \
+ {-shared -fPIC -Wl,--as-needed tmpdir/pr27441c.o tmpdir/pr27441b.so tmpdir/pr27441a.so} {-fPIC} \
+ {dummy.c} {{readelf {-dW} pr27441c.d}} {pr27441c.so}] \
++ [list \
++ "Build libpr28879a.so" \
++ "-shared" \
++ "-O0 -fpic" \
++ {pr28879a.cc} \
++ {} \
++ "libpr28879a.so" \
++ "c++" \
++ ] \
++ [list \
++ "Build libpr28879b.so" \
++ "-shared -Wl,--no-as-needed tmpdir/libpr28879a.so" \
++ "-O2 -fpic" \
++ {dummy.c} \
++ {} \
++ "libpr28879b.so" \
++ ] \
++ [list \
++ "Build pr28879" \
++ "-Wl,--no-as-needed tmpdir/libpr28879b.so -Wl,-rpath-link,." \
++ "-O0 -flto -D_GLIBCXX_ASSERTIONS" \
++ {pr28879b.cc} \
++ {} \
++ "pr28879" \
++ "c++" \
++ ] \
+ ]
+
+ # PR 14918 checks that libgcc is not spuriously included in a shared link of
+diff --git a/ld/testsuite/ld-plugin/pr28879a.cc b/ld/testsuite/ld-plugin/pr28879a.cc
+new file mode 100644
+index 00000000000..8307a42e2fb
+--- /dev/null
++++ b/ld/testsuite/ld-plugin/pr28879a.cc
+@@ -0,0 +1,7 @@
++#include <string>
++
++void
++func (std::string *s)
++{
++ delete s;
++}
+diff --git a/ld/testsuite/ld-plugin/pr28879b.cc b/ld/testsuite/ld-plugin/pr28879b.cc
+new file mode 100644
+index 00000000000..02fc351366c
+--- /dev/null
++++ b/ld/testsuite/ld-plugin/pr28879b.cc
+@@ -0,0 +1,8 @@
++#include <string>
++
++int
++main (void)
++{
++ std::string header;
++ return 0;
++}
+--
+2.35.1
+
More information about the arch-commits
mailing list