summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/IA64/IA64AsmPrinter.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2005-11-21 08:38:26 +0000
committerChris Lattner <sabre@nondot.org>2005-11-21 08:38:26 +0000
commitb55de47595c127f56a29116af7403b416f3bd551 (patch)
tree5556b639cd0c2b70167776ca1d76d932db22130e /llvm/lib/Target/IA64/IA64AsmPrinter.cpp
parent4a7eb5132b4a7797cb61be3fc060072834d3e68b (diff)
downloadbcm5719-llvm-b55de47595c127f56a29116af7403b416f3bd551.tar.gz
bcm5719-llvm-b55de47595c127f56a29116af7403b416f3bd551.zip
Start using shared asmprinter Constant Pool emitter, use shorter cpi names.
llvm-svn: 24469
Diffstat (limited to 'llvm/lib/Target/IA64/IA64AsmPrinter.cpp')
-rw-r--r--llvm/lib/Target/IA64/IA64AsmPrinter.cpp31
1 files changed, 5 insertions, 26 deletions
diff --git a/llvm/lib/Target/IA64/IA64AsmPrinter.cpp b/llvm/lib/Target/IA64/IA64AsmPrinter.cpp
index c2a7b93e769..d3cb56dd45c 100644
--- a/llvm/lib/Target/IA64/IA64AsmPrinter.cpp
+++ b/llvm/lib/Target/IA64/IA64AsmPrinter.cpp
@@ -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;
}
OpenPOWER on IntegriCloud