diff options
author | Davide Italiano <davide@freebsd.org> | 2016-06-22 20:48:15 +0000 |
---|---|---|
committer | Davide Italiano <davide@freebsd.org> | 2016-06-22 20:48:15 +0000 |
commit | ec7e29e9419b083b5e3f9d0873ce8b35849a8cf8 (patch) | |
tree | 591dda5fccd5cbbcd8fd3ae8e7f6a0d0284df4a2 /llvm | |
parent | 84d63720109de7faef83116010c43628dd6d5c87 (diff) | |
download | bcm5719-llvm-ec7e29e9419b083b5e3f9d0873ce8b35849a8cf8.tar.gz bcm5719-llvm-ec7e29e9419b083b5e3f9d0873ce8b35849a8cf8.zip |
[IRObjectFile] Propagate .weak attribute correctly for ASM symbols.
PR: 28256
Differential Revision: http://reviews.llvm.org/D21616
llvm-svn: 273474
Diffstat (limited to 'llvm')
-rw-r--r-- | llvm/lib/Object/IRObjectFile.cpp | 3 | ||||
-rw-r--r-- | llvm/lib/Object/RecordStreamer.cpp | 14 | ||||
-rw-r--r-- | llvm/lib/Object/RecordStreamer.h | 4 | ||||
-rw-r--r-- | llvm/test/Object/X86/nm-bitcodeweak.test | 2 |
4 files changed, 16 insertions, 7 deletions
diff --git a/llvm/lib/Object/IRObjectFile.cpp b/llvm/lib/Object/IRObjectFile.cpp index 5c943be459b..fdc53e01e36 100644 --- a/llvm/lib/Object/IRObjectFile.cpp +++ b/llvm/lib/Object/IRObjectFile.cpp @@ -116,6 +116,9 @@ void IRObjectFile::CollectAsmUndefinedRefs( Res |= BasicSymbolRef::SF_Undefined; Res |= BasicSymbolRef::SF_Global; break; + case RecordStreamer::GlobalWeak: + Res |= BasicSymbolRef::SF_Weak; + Res |= BasicSymbolRef::SF_Global; } AsmUndefinedRefs(Key, BasicSymbolRef::Flags(Res)); } diff --git a/llvm/lib/Object/RecordStreamer.cpp b/llvm/lib/Object/RecordStreamer.cpp index 74d57dee2da..f03bd5e5fb9 100644 --- a/llvm/lib/Object/RecordStreamer.cpp +++ b/llvm/lib/Object/RecordStreamer.cpp @@ -23,21 +23,26 @@ void RecordStreamer::markDefined(const MCSymbol &Symbol) { case Used: S = Defined; break; + case GlobalWeak: + break; } } -void RecordStreamer::markGlobal(const MCSymbol &Symbol) { +void RecordStreamer::markGlobal(const MCSymbol &Symbol, + MCSymbolAttr Attribute) { State &S = Symbols[Symbol.getName()]; switch (S) { case DefinedGlobal: case Defined: - S = DefinedGlobal; + S = (Attribute == MCSA_Weak) ? GlobalWeak : DefinedGlobal; break; case NeverSeen: case Global: case Used: - S = Global; + S = (Attribute == MCSA_Weak) ? GlobalWeak : Global; + break; + case GlobalWeak: break; } } @@ -48,6 +53,7 @@ void RecordStreamer::markUsed(const MCSymbol &Symbol) { case DefinedGlobal: case Defined: case Global: + case GlobalWeak: break; case NeverSeen: @@ -85,7 +91,7 @@ void RecordStreamer::EmitAssignment(MCSymbol *Symbol, const MCExpr *Value) { bool RecordStreamer::EmitSymbolAttribute(MCSymbol *Symbol, MCSymbolAttr Attribute) { if (Attribute == MCSA_Global || Attribute == MCSA_Weak) - markGlobal(*Symbol); + markGlobal(*Symbol, Attribute); return true; } diff --git a/llvm/lib/Object/RecordStreamer.h b/llvm/lib/Object/RecordStreamer.h index d8610610c33..71337a60591 100644 --- a/llvm/lib/Object/RecordStreamer.h +++ b/llvm/lib/Object/RecordStreamer.h @@ -15,12 +15,12 @@ namespace llvm { class RecordStreamer : public MCStreamer { public: - enum State { NeverSeen, Global, Defined, DefinedGlobal, Used }; + enum State { NeverSeen, Global, GlobalWeak, Defined, DefinedGlobal, Used }; private: StringMap<State> Symbols; void markDefined(const MCSymbol &Symbol); - void markGlobal(const MCSymbol &Symbol); + void markGlobal(const MCSymbol &Symbol, MCSymbolAttr Attribute); void markUsed(const MCSymbol &Symbol); void visitUsedSymbol(const MCSymbol &Sym) override; diff --git a/llvm/test/Object/X86/nm-bitcodeweak.test b/llvm/test/Object/X86/nm-bitcodeweak.test index 19af95f1ae8..3333068bb36 100644 --- a/llvm/test/Object/X86/nm-bitcodeweak.test +++ b/llvm/test/Object/X86/nm-bitcodeweak.test @@ -1,7 +1,7 @@ ; RUN: llvm-as %s -o=%t1 ; RUN: llvm-nm %t1 | FileCheck %s -; CHECK: T __libc_blah +; CHECK: W __libc_blah target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128" target triple = "x86_64-unknown-freebsd11.0" |