Use the shared asmprinter code for printing special llvm globals

llvm-svn: 24695
diff --git a/llvm/lib/Target/PowerPC/PPCAsmPrinter.cpp b/llvm/lib/Target/PowerPC/PPCAsmPrinter.cpp
index 2fbf9ec..3fa73a6 100644
--- a/llvm/lib/Target/PowerPC/PPCAsmPrinter.cpp
+++ b/llvm/lib/Target/PowerPC/PPCAsmPrinter.cpp
@@ -198,14 +198,14 @@
       AlignmentIsInBytes = false;    // Alignment is by power of 2.
       ConstantPoolSection = "\t.const\t";
       LCOMMDirective = "\t.lcomm\t";
+      StaticCtorsSection = ".mod_init_func";
+      StaticDtorsSection = ".mod_term_func";
     }
 
     virtual const char *getPassName() const {
       return "Darwin PPC Assembly Printer";
     }
     
-    void EmitXXStructorList(Constant *List);
-
     bool runOnMachineFunction(MachineFunction &F);
     bool doInitialization(Module &M);
     bool doFinalization(Module &M);
@@ -415,21 +415,6 @@
   return false;
 }
 
-/// EmitXXStructorList - Emit the ctor or dtor list.  On darwin, this just 
-/// prints out the function pointers.
-void DarwinAsmPrinter::EmitXXStructorList(Constant *List) {
-  // Should be an array of '{ int, void ()* }' structs.  The first value is the
-  // init priority, which we ignore.
-  if (!isa<ConstantArray>(List)) return;
-  ConstantArray *InitList = cast<ConstantArray>(List);
-  for (unsigned i = 0, e = InitList->getNumOperands(); i != e; ++i)
-    if (ConstantStruct *CS = dyn_cast<ConstantStruct>(InitList->getOperand(i))){
-      if (CS->getNumOperands() != 2) return;  // Not array of 2-element structs.
-      // Emit the function pointer.
-      EmitGlobalConstant(CS->getOperand(1));
-    }
-}
-
 bool DarwinAsmPrinter::doFinalization(Module &M) {
   const TargetData &TD = TM.getTargetData();
 
@@ -438,22 +423,9 @@
        I != E; ++I) {
     if (!I->hasInitializer()) continue;   // External global require no code
     
-    // Check to see if this is a special global used by LLVM.
-    if (I->hasAppendingLinkage()) {
-      if (I->getName() == "llvm.used")
-        continue;  // No need to emit this at all.
-      if (I->getName() == "llvm.global_ctors") {
-        SwitchSection(".mod_init_func", 0);
-        EmitAlignment(2, 0);
-        EmitXXStructorList(I->getInitializer());
-        continue;
-      } else if (I->getName() == "llvm.global_dtors") {
-        SwitchSection(".mod_term_func", 0);
-        EmitAlignment(2, 0);
-        EmitXXStructorList(I->getInitializer());
-        continue;
-      }
-    }
+    // Check to see if this is a special global used by LLVM, if so, emit it.
+    if (I->hasAppendingLinkage() && EmitSpecialLLVMGlobal(I))
+      continue;
     
     O << '\n';
     std::string name = Mang->getValueName(I);
diff --git a/llvm/lib/Target/X86/X86AsmPrinter.cpp b/llvm/lib/Target/X86/X86AsmPrinter.cpp
index 13c136f..f3505fb 100644
--- a/llvm/lib/Target/X86/X86AsmPrinter.cpp
+++ b/llvm/lib/Target/X86/X86AsmPrinter.cpp
@@ -58,6 +58,8 @@
     COMMDirectiveTakesAlignment = false;
     HasDotTypeDotSizeDirective = false;
     forDarwin = true;
+    StaticCtorsSection = ".mod_init_func";
+    StaticDtorsSection = ".mod_term_func";
     break;
   case X86Subtarget::isCygwin:
     GlobalPrefix = "_";
@@ -74,21 +76,6 @@
   return AsmPrinter::doInitialization(M);
 }
 
-/// EmitXXStructorList - Emit the ctor or dtor list.  On darwin, this just 
-/// prints out the function pointers.
-void X86SharedAsmPrinter::EmitXXStructorList(Constant *List) {
-  // Should be an array of '{ int, void ()* }' structs.  The first value is the
-  // init priority, which we ignore.
-  if (!isa<ConstantArray>(List)) return;
-  ConstantArray *InitList = cast<ConstantArray>(List);
-  for (unsigned i = 0, e = InitList->getNumOperands(); i != e; ++i)
-    if (ConstantStruct *CS = dyn_cast<ConstantStruct>(InitList->getOperand(i))){
-      if (CS->getNumOperands() != 2) return;  // Not array of 2-element structs.
-                                              // Emit the function pointer.
-      EmitGlobalConstant(CS->getOperand(1));
-    }
-}
-
 bool X86SharedAsmPrinter::doFinalization(Module &M) {
   const TargetData &TD = TM.getTargetData();
 
@@ -97,28 +84,9 @@
        E = M.global_end(); I != E; ++I) {
     if (!I->hasInitializer()) continue;   // External global require no code
     
-    // Check to see if this is a special global used by LLVM.
-    if (I->hasAppendingLinkage()) {
-      if (I->getName() == "llvm.used")
-        continue;  // No need to emit this at all.
-      if (I->getName() == "llvm.global_ctors") {
-        if (forDarwin)
-          SwitchSection(".mod_init_func", 0);
-        else
-          SwitchSection(".ctors,\"aw\",@progbits", 0);
-        EmitAlignment(2, 0);
-        EmitXXStructorList(I->getInitializer());
-        continue;
-      } else if (I->getName() == "llvm.global_dtors") {
-        if (forDarwin)
-          SwitchSection(".mod_term_func", 0);
-        else
-          SwitchSection(".dtors,\"aw\",@progbits", 0);
-        EmitAlignment(2, 0);
-        EmitXXStructorList(I->getInitializer());
-        continue;
-      }
-    }
+    // Check to see if this is a special global used by LLVM, if so, emit it.
+    if (I->hasAppendingLinkage() && EmitSpecialLLVMGlobal(I))
+      continue;
     
     O << "\n\n";
     std::string name = Mang->getValueName(I);
diff --git a/llvm/lib/Target/X86/X86AsmPrinter.h b/llvm/lib/Target/X86/X86AsmPrinter.h
index a2e5f2f..3267d4e 100755
--- a/llvm/lib/Target/X86/X86AsmPrinter.h
+++ b/llvm/lib/Target/X86/X86AsmPrinter.h
@@ -33,7 +33,6 @@
 
   bool doInitialization(Module &M);
   bool doFinalization(Module &M);
-  void EmitXXStructorList(Constant *List);
 
   bool forDarwin;  // FIXME: eliminate.