aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2014-07-04 15:03:17 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2014-07-04 15:03:17 +0000
commitb674c17deb160951448c94e206488afb258e9fa3 (patch)
tree50c60e96b2f65fb794fee4de6bb78703cdc9442d
parentd749fb5129fe75246c984bf7771bd62906a4b3cc (diff)
downloadllvm-b674c17deb160951448c94e206488afb258e9fa3.zip
llvm-b674c17deb160951448c94e206488afb258e9fa3.tar.gz
llvm-b674c17deb160951448c94e206488afb258e9fa3.tar.bz2
Don't include llvm.metadata variables in archive symbol tables.
llvm-svn: 212344
-rw-r--r--llvm/lib/Object/IRObjectFile.cpp5
-rw-r--r--llvm/test/Object/Inputs/trivial.ll3
-rw-r--r--llvm/test/Object/nm-archive.test1
3 files changed, 9 insertions, 0 deletions
diff --git a/llvm/lib/Object/IRObjectFile.cpp b/llvm/lib/Object/IRObjectFile.cpp
index 5039405..d0191081 100644
--- a/llvm/lib/Object/IRObjectFile.cpp
+++ b/llvm/lib/Object/IRObjectFile.cpp
@@ -240,6 +240,11 @@ uint32_t IRObjectFile::getSymbolFlags(DataRefImpl Symb) const {
if (GV->hasLinkOnceLinkage() || GV->hasWeakLinkage())
Res |= BasicSymbolRef::SF_Weak;
+ if (auto *Var = dyn_cast<GlobalVariable>(GV)) {
+ if (Var->getSection() == StringRef("llvm.metadata"))
+ Res |= BasicSymbolRef::SF_FormatSpecific;
+ }
+
return Res;
}
diff --git a/llvm/test/Object/Inputs/trivial.ll b/llvm/test/Object/Inputs/trivial.ll
index 25ece76..622d1e97 100644
--- a/llvm/test/Object/Inputs/trivial.ll
+++ b/llvm/test/Object/Inputs/trivial.ll
@@ -10,3 +10,6 @@ entry:
declare i32 @puts(i8* nocapture) nounwind
declare void @SomeOtherFunction(...)
+
+@var = global i32 0
+@llvm.used = appending global [1 x i8*] [i8* bitcast (i32* @var to i8*)], section "llvm.metadata"
diff --git a/llvm/test/Object/nm-archive.test b/llvm/test/Object/nm-archive.test
index d875d6c..9cb84b2 100644
--- a/llvm/test/Object/nm-archive.test
+++ b/llvm/test/Object/nm-archive.test
@@ -18,6 +18,7 @@ RUN: llvm-nm %t2 | FileCheck %s -check-prefix BITCODE
BITCODE: U SomeOtherFunction
BITCODE-NEXT: T main
BITCODE-NEXT: U puts
+BITCODE-NEXT: D var
Test we don't error with an archive with no symtab.