From 2580d4f232ce0885e1ffc03240ebbcc031b05a43 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Mon, 3 Nov 2003 17:32:38 +0000 Subject: [PATCH] Fix bugs with attribute weak emission git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@9678 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Target/CBackend/CBackend.cpp | 9 ++++++--- lib/Target/CBackend/Writer.cpp | 9 ++++++--- 2 files changed, 12 insertions(+), 6 deletions(-) diff --git a/lib/Target/CBackend/CBackend.cpp b/lib/Target/CBackend/CBackend.cpp index e32987cbd2e..0fd30460214 100644 --- a/lib/Target/CBackend/CBackend.cpp +++ b/lib/Target/CBackend/CBackend.cpp @@ -653,6 +653,7 @@ void CWriter::printModule(Module *M) { if ((I->hasInternalLinkage() || !MangledGlobals.count(I)) && !I->getIntrinsicID()) { printFunctionSignature(I, true); + if (I->hasWeakLinkage()) Out << " __attribute__((weak))"; Out << ";\n"; } } @@ -671,7 +672,11 @@ void CWriter::printModule(Module *M) { if (!I->isExternal()) { Out << "extern "; printType(Out, I->getType()->getElementType(), Mang->getValueName(I)); - + + if (I->hasLinkOnceLinkage()) + Out << " __attribute__((common))"; + else if (I->hasWeakLinkage()) + Out << " __attribute__((weak))"; Out << ";\n"; } } @@ -903,8 +908,6 @@ void CWriter::printFunctionSignature(const Function *F, bool Prototype) { FunctionInnards << ")"; // Print out the return type and the entire signature for that matter printType(Out, F->getReturnType(), FunctionInnards.str()); - - if (F->hasWeakLinkage()) Out << " __attribute((weak))"; } void CWriter::printFunction(Function *F) { diff --git a/lib/Target/CBackend/Writer.cpp b/lib/Target/CBackend/Writer.cpp index e32987cbd2e..0fd30460214 100644 --- a/lib/Target/CBackend/Writer.cpp +++ b/lib/Target/CBackend/Writer.cpp @@ -653,6 +653,7 @@ void CWriter::printModule(Module *M) { if ((I->hasInternalLinkage() || !MangledGlobals.count(I)) && !I->getIntrinsicID()) { printFunctionSignature(I, true); + if (I->hasWeakLinkage()) Out << " __attribute__((weak))"; Out << ";\n"; } } @@ -671,7 +672,11 @@ void CWriter::printModule(Module *M) { if (!I->isExternal()) { Out << "extern "; printType(Out, I->getType()->getElementType(), Mang->getValueName(I)); - + + if (I->hasLinkOnceLinkage()) + Out << " __attribute__((common))"; + else if (I->hasWeakLinkage()) + Out << " __attribute__((weak))"; Out << ";\n"; } } @@ -903,8 +908,6 @@ void CWriter::printFunctionSignature(const Function *F, bool Prototype) { FunctionInnards << ")"; // Print out the return type and the entire signature for that matter printType(Out, F->getReturnType(), FunctionInnards.str()); - - if (F->hasWeakLinkage()) Out << " __attribute((weak))"; } void CWriter::printFunction(Function *F) { -- 2.34.1