summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--lld/ELF/InputFiles.cpp7
-rw-r--r--lld/test/ELF/Inputs/start-lib1.s3
-rw-r--r--lld/test/ELF/Inputs/start-lib2.s2
-rw-r--r--lld/test/ELF/start-lib.s23
4 files changed, 26 insertions, 9 deletions
diff --git a/lld/ELF/InputFiles.cpp b/lld/ELF/InputFiles.cpp
index 52b6d447a9b..b8681e5581f 100644
--- a/lld/ELF/InputFiles.cpp
+++ b/lld/ELF/InputFiles.cpp
@@ -594,7 +594,8 @@ template <class ELFT> std::vector<StringRef> LazyObjectFile::getElfSymbols() {
StringRef StringTable = check(Obj.getStringTableForSymtab(Sec));
std::vector<StringRef> V;
for (const Elf_Sym &Sym : Syms.slice(FirstNonLocal))
- V.push_back(check(Sym.getName(StringTable)));
+ if (Sym.st_shndx != SHN_UNDEF)
+ V.push_back(check(Sym.getName(StringTable)));
return V;
}
return {};
@@ -608,6 +609,8 @@ std::vector<StringRef> LazyObjectFile::getBitcodeSymbols() {
for (const BasicSymbolRef &Sym : Obj->symbols()) {
if (BitcodeFile::shouldSkip(Sym))
continue;
+ if (Sym.getFlags() == BasicSymbolRef::SF_Undefined)
+ continue;
SmallString<64> Name;
raw_svector_ostream OS(Name);
Sym.printName(OS);
@@ -616,7 +619,7 @@ std::vector<StringRef> LazyObjectFile::getBitcodeSymbols() {
return V;
}
-// Returns a vector of globally-visible symbol names.
+// Returns a vector of globally-visible defined symbol names.
std::vector<StringRef> LazyObjectFile::getSymbols() {
if (isBitcode(this->MB))
return getBitcodeSymbols();
diff --git a/lld/test/ELF/Inputs/start-lib1.s b/lld/test/ELF/Inputs/start-lib1.s
new file mode 100644
index 00000000000..d401b20e65d
--- /dev/null
+++ b/lld/test/ELF/Inputs/start-lib1.s
@@ -0,0 +1,3 @@
+.globl foo
+foo:
+ call bar
diff --git a/lld/test/ELF/Inputs/start-lib2.s b/lld/test/ELF/Inputs/start-lib2.s
new file mode 100644
index 00000000000..f500936565f
--- /dev/null
+++ b/lld/test/ELF/Inputs/start-lib2.s
@@ -0,0 +1,2 @@
+.globl bar
+bar:
diff --git a/lld/test/ELF/start-lib.s b/lld/test/ELF/start-lib.s
index caec1a5009c..013a2b206a1 100644
--- a/lld/test/ELF/start-lib.s
+++ b/lld/test/ELF/start-lib.s
@@ -2,15 +2,24 @@
// RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %s -o %t1.o
// RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux \
-// RUN: %p/Inputs/whole-archive.s -o %t2.o
+// RUN: %p/Inputs/start-lib1.s -o %t2.o
+// RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux \
+// RUN: %p/Inputs/start-lib2.s -o %t3.o
+
+// RUN: ld.lld -o %t3 %t1.o %t2.o %t3.o
+// RUN: llvm-readobj --symbols %t3 | FileCheck --check-prefix=TEST1 %s
+// TEST1: Name: bar
+// TEST1: Name: foo
-// RUN: ld.lld -o %t3 %t1.o %t2.o
-// RUN: llvm-readobj --symbols %t3 | FileCheck --check-prefix=ADDED %s
-// ADDED: Name: _bar
+// RUN: ld.lld -o %t3 %t1.o -u bar --start-lib %t2.o %t3.o
+// RUN: llvm-readobj --symbols %t3 | FileCheck --check-prefix=TEST2 %s
+// TEST2: Name: bar
+// TEST2-NOT: Name: foo
-// RUN: ld.lld -o %t3 %t1.o --start-lib %t2.o
-// RUN: llvm-readobj --symbols %t3 | FileCheck --check-prefix=LIB %s
-// LIB-NOT: Name: _bar
+// RUN: ld.lld -o %t3 %t1.o --start-lib %t2.o %t3.o
+// RUN: llvm-readobj --symbols %t3 | FileCheck --check-prefix=TEST3 %s
+// TEST3-NOT: Name: bar
+// TEST3-NOT: Name: foo
.globl _start
_start:
OpenPOWER on IntegriCloud