[llvm-commits] CVS: llvm/lib/Target/IA64/IA64AsmPrinter.cpp

Chris Lattner lattner at cs.uiuc.edu
Mon Nov 21 00:38:38 PST 2005



Changes in directory llvm/lib/Target/IA64:

IA64AsmPrinter.cpp updated: 1.18 -> 1.19
---
Log message:

Start using shared asmprinter Constant Pool emitter, use shorter cpi names.


---
Diffs of the changes:  (+5 -26)

 IA64AsmPrinter.cpp |   31 +++++--------------------------
 1 files changed, 5 insertions(+), 26 deletions(-)


Index: llvm/lib/Target/IA64/IA64AsmPrinter.cpp
diff -u llvm/lib/Target/IA64/IA64AsmPrinter.cpp:1.18 llvm/lib/Target/IA64/IA64AsmPrinter.cpp:1.19
--- llvm/lib/Target/IA64/IA64AsmPrinter.cpp:1.18	Mon Nov 21 01:51:23 2005
+++ llvm/lib/Target/IA64/IA64AsmPrinter.cpp	Mon Nov 21 02:38:26 2005
@@ -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 @@
     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 @@
       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 @@
   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 @@
     return;
 
   case MachineOperand::MO_ConstantPoolIndex: {
-    O << "@gprel(" << PrivateGlobalPrefix << "CPI" << CurrentFnName << "_"
+    O << "@gprel(" << PrivateGlobalPrefix << "CPI" << getFunctionNumber() << "_"
       << MO.getConstantPoolIndex() << ")";
     return;
   }






More information about the llvm-commits mailing list