From 90107652c06eecbd6676b4b3178c4ed448a15270 Mon Sep 17 00:00:00 2001 From: Davide Italiano Date: Wed, 22 Jun 2016 20:48:15 +0000 Subject: [PATCH] [IRObjectFile] Propagate .weak attribute correctly for ASM symbols. PR: 28256 Differential Revision: http://reviews.llvm.org/D21616 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@273474 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Object/IRObjectFile.cpp | 3 +++ lib/Object/RecordStreamer.cpp | 14 ++++++++++---- lib/Object/RecordStreamer.h | 4 ++-- test/Object/X86/nm-bitcodeweak.test | 2 +- 4 files changed, 16 insertions(+), 7 deletions(-) diff --git a/lib/Object/IRObjectFile.cpp b/lib/Object/IRObjectFile.cpp index 5c943be459b..fdc53e01e36 100644 --- a/lib/Object/IRObjectFile.cpp +++ b/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/lib/Object/RecordStreamer.cpp b/lib/Object/RecordStreamer.cpp index 74d57dee2da..f03bd5e5fb9 100644 --- a/lib/Object/RecordStreamer.cpp +++ b/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/lib/Object/RecordStreamer.h b/lib/Object/RecordStreamer.h index d8610610c33..71337a60591 100644 --- a/lib/Object/RecordStreamer.h +++ b/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 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/test/Object/X86/nm-bitcodeweak.test b/test/Object/X86/nm-bitcodeweak.test index 19af95f1ae8..3333068bb36 100644 --- a/test/Object/X86/nm-bitcodeweak.test +++ b/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" -- 2.11.0