diff options
author | Dale Johannesen <dalej@apple.com> | 2008-05-16 00:52:06 +0000 |
---|---|---|
committer | Dale Johannesen <dalej@apple.com> | 2008-05-16 00:52:06 +0000 |
commit | f88c81e332a46e1e41761577067d5597535b06b9 (patch) | |
tree | c4d0d404030a7ef80ade3b60d868556a93408adb /lib/Target/X86/X86AsmPrinter.cpp | |
parent | eedff319dc24652431cafc9df8ff84d26f9cdc9d (diff) | |
download | external_llvm-f88c81e332a46e1e41761577067d5597535b06b9.zip external_llvm-f88c81e332a46e1e41761577067d5597535b06b9.tar.gz external_llvm-f88c81e332a46e1e41761577067d5597535b06b9.tar.bz2 |
Treat common as distinct from weak global on Darwin x86.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@51172 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/X86/X86AsmPrinter.cpp')
-rw-r--r-- | lib/Target/X86/X86AsmPrinter.cpp | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/lib/Target/X86/X86AsmPrinter.cpp b/lib/Target/X86/X86AsmPrinter.cpp index 3898a9e..a99588b 100644 --- a/lib/Target/X86/X86AsmPrinter.cpp +++ b/lib/Target/X86/X86AsmPrinter.cpp @@ -211,6 +211,16 @@ bool X86SharedAsmPrinter::doFinalization(Module &M) { O << TAI->getLCOMMDirective() << name << "," << Size; if (Subtarget->isTargetDarwin()) O << "," << Align; + } else if (Subtarget->isTargetDarwin() && !I->hasCommonLinkage()) { + O << "\t.globl " << name << "\n" + << TAI->getWeakDefDirective() << name << "\n"; + SwitchToDataSection("\t.section __DATA,__datacoal_nt,coalesced", I); + EmitAlignment(Align, I); + O << name << ":\t\t\t\t" << TAI->getCommentString() << " "; + PrintUnmangledNameSafely(I, O); + O << "\n"; + EmitGlobalConstant(C); + continue; } else { O << TAI->getCOMMDirective() << name << "," << Size; |