diff options
author | Chris Lattner <sabre@nondot.org> | 2010-01-19 04:34:02 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2010-01-19 04:34:02 +0000 |
commit | e9d28b19cf3864c0e44e15036dc71e8e4eb31088 (patch) | |
tree | 57430d35bc32d0a9143f9c43608caf92c1c5c4bf /llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp | |
parent | 58d59fe394e7c773bff27b412d90f5d0523187aa (diff) | |
download | bcm5719-llvm-e9d28b19cf3864c0e44e15036dc71e8e4eb31088.tar.gz bcm5719-llvm-e9d28b19cf3864c0e44e15036dc71e8e4eb31088.zip |
move production of .reference directives for static ctor/dtor list on
darwin into common code.
llvm-svn: 93849
Diffstat (limited to 'llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp')
-rw-r--r-- | llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp b/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp index 3beb4d66ac8..9a19f81e38b 100644 --- a/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp +++ b/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp @@ -449,6 +449,10 @@ bool AsmPrinter::EmitSpecialLLVMGlobal(const GlobalVariable *GV) { OutStreamer.SwitchSection(getObjFileLowering().getStaticCtorSection()); EmitAlignment(Align, 0); EmitXXStructorList(GV->getInitializer()); + + if (TM.getRelocationModel() == Reloc::Static && + MAI->hasStaticCtorDtorReferenceInStaticMode()) + O << ".reference .constructors_used\n"; return true; } @@ -456,6 +460,10 @@ bool AsmPrinter::EmitSpecialLLVMGlobal(const GlobalVariable *GV) { OutStreamer.SwitchSection(getObjFileLowering().getStaticDtorSection()); EmitAlignment(Align, 0); EmitXXStructorList(GV->getInitializer()); + + if (TM.getRelocationModel() == Reloc::Static && + MAI->hasStaticCtorDtorReferenceInStaticMode()) + O << ".reference .destructors_used\n"; return true; } |