summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavide Italiano <davide@freebsd.org>2016-03-29 04:34:09 +0000
committerDavide Italiano <davide@freebsd.org>2016-03-29 04:34:09 +0000
commit3acdfeee1115ff2bf55ad44cae39d6360b5500df (patch)
tree8a44333e51296e33f2ca3e7a1855910372e9ee00
parent4673f1056820347dfae0475a4005744b9756a0b5 (diff)
downloadbcm5719-llvm-3acdfeee1115ff2bf55ad44cae39d6360b5500df.tar.gz
bcm5719-llvm-3acdfeee1115ff2bf55ad44cae39d6360b5500df.zip
[LTO] Don't internalize if --export-dynamic is passed.
We treat that in the same way we treat shared libraries. llvm-svn: 264698
-rw-r--r--lld/ELF/LTO.cpp2
-rw-r--r--lld/test/ELF/lto/internalize-exportdyn.ll19
2 files changed, 20 insertions, 1 deletions
diff --git a/lld/ELF/LTO.cpp b/lld/ELF/LTO.cpp
index 528a914b6a1..76a5b06ad11 100644
--- a/lld/ELF/LTO.cpp
+++ b/lld/ELF/LTO.cpp
@@ -106,7 +106,7 @@ void BitcodeCompiler::add(BitcodeFile &F) {
// Shared libraries need to be handled slightly differently.
// For now, let's be conservative and just never internalize
// symbols when creating a shared library.
- if (!Config->Shared && !B->isUsedInRegularObj())
+ if (!Config->Shared && !Config->ExportDynamic && !B->isUsedInRegularObj())
InternalizedSyms.insert(GV->getName());
Keep.push_back(GV);
diff --git a/lld/test/ELF/lto/internalize-exportdyn.ll b/lld/test/ELF/lto/internalize-exportdyn.ll
new file mode 100644
index 00000000000..b9333c89cfb
--- /dev/null
+++ b/lld/test/ELF/lto/internalize-exportdyn.ll
@@ -0,0 +1,19 @@
+; REQUIRES: x86
+; RUN: llvm-as %s -o %t.o
+; RUN: ld.lld -m elf_x86_64 %t.o -o %t2 --export-dynamic -save-temps
+; RUN: llvm-dis < %t2.lto.bc | FileCheck %s
+
+target triple = "x86_64-unknown-linux-gnu"
+target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
+
+define void @_start() {
+ ret void
+}
+
+define hidden void @foo() {
+ ret void
+}
+
+; Check that _start and foo are not internalized.
+; CHECK: define void @_start()
+; CHECK: define hidden void @foo()
OpenPOWER on IntegriCloud