Start using shared asmprinter Constant Pool emitter, use shorter cpi names.
authorChris Lattner <sabre@nondot.org>
Mon, 21 Nov 2005 08:38:26 +0000 (08:38 +0000)
committerChris Lattner <sabre@nondot.org>
Mon, 21 Nov 2005 08:38:26 +0000 (08:38 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@24469 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/IA64/IA64AsmPrinter.cpp

index c2a7b93e769e9b00ddbc9f050b05382fcce7c7e9..d3cb56dd45c4903e59103ca753dfe3cf07679f19 100644 (file)
@@ -22,7 +22,6 @@
 #include "llvm/Type.h"
 #include "llvm/Assembly/Writer.h"
 #include "llvm/CodeGen/AsmPrinter.h"
-#include "llvm/CodeGen/MachineConstantPool.h"
 #include "llvm/CodeGen/MachineFunctionPass.h"
 #include "llvm/CodeGen/ValueTypes.h"
 #include "llvm/Target/TargetMachine.h"
@@ -41,32 +40,10 @@ namespace {
     IA64SharedAsmPrinter(std::ostream &O, TargetMachine &TM)
       : AsmPrinter(O, TM) { }
 
-    void printConstantPool(MachineConstantPool *MCP);
     bool doFinalization(Module &M);
   };
 }
 
-/// printConstantPool - Print to the current output stream assembly
-/// representations of the constants in the constant pool MCP. This is
-/// used to print out constants which have been "spilled to memory" by
-/// the code generator.
-///
-void IA64SharedAsmPrinter::printConstantPool(MachineConstantPool *MCP) {
-  const std::vector<Constant*> &CP = MCP->getConstants();
-  const TargetData &TD = TM.getTargetData();
-
-  if (CP.empty()) return;
-
-  // FIXME: would be nice to have rodata (no 'w') when appropriate?
-  SwitchSection("\n\t.section .data, \"aw\", \"progbits\"\n", 0);
-  for (unsigned i = 0, e = CP.size(); i != e; ++i) {
-    EmitAlignment(TD.getTypeAlignmentShift(CP[i]->getType()));
-    O << PrivateGlobalPrefix << "CPI" << CurrentFnName << "_" << i
-      << ":\t\t\t\t\t" << CommentString << *CP[i] << "\n";
-    EmitGlobalConstant(CP[i]);
-  }
-}
-
 bool IA64SharedAsmPrinter::doFinalization(Module &M) {
   const TargetData &TD = TM.getTargetData();
 
@@ -169,7 +146,9 @@ namespace {
       GlobalVarAddrSuffix="";
       FunctionAddrPrefix="@fptr(";
       FunctionAddrSuffix=")";
-
+      
+      // FIXME: would be nice to have rodata (no 'w') when appropriate?
+      ConstantPoolSection = "\n\t.section .data, \"aw\", \"progbits\"\n";
     }
 
     virtual const char *getPassName() const {
@@ -264,7 +243,7 @@ bool IA64AsmPrinter::runOnMachineFunction(MachineFunction &MF) {
   O << "\n\n";
 
   // Print out constants referenced by the function
-  printConstantPool(MF.getConstantPool());
+  EmitConstantPool(MF.getConstantPool());
 
   // Print out labels for the function.
   SwitchSection("\n\t.section .text, \"ax\", \"progbits\"\n", MF.getFunction());
@@ -328,7 +307,7 @@ void IA64AsmPrinter::printOp(const MachineOperand &MO,
     return;
 
   case MachineOperand::MO_ConstantPoolIndex: {
-    O << "@gprel(" << PrivateGlobalPrefix << "CPI" << CurrentFnName << "_"
+    O << "@gprel(" << PrivateGlobalPrefix << "CPI" << getFunctionNumber() << "_"
       << MO.getConstantPoolIndex() << ")";
     return;
   }