summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/ARM/ARMCodeEmitter.cpp
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2008-10-31 19:55:13 +0000
committerEvan Cheng <evan.cheng@apple.com>2008-10-31 19:55:13 +0000
commit20dbb3bcad3c32330290abef066e1e1465fd2a3f (patch)
tree8ccbc7163afa2079672174a81775a856f4075b5e /llvm/lib/Target/ARM/ARMCodeEmitter.cpp
parent44994e0c77d31ca95afebcdb3172776c01d23bec (diff)
downloadbcm5719-llvm-20dbb3bcad3c32330290abef066e1e1465fd2a3f.tar.gz
bcm5719-llvm-20dbb3bcad3c32330290abef066e1e1465fd2a3f.zip
Use better data structure for ConstPoolId2AddrMap.
llvm-svn: 58532
Diffstat (limited to 'llvm/lib/Target/ARM/ARMCodeEmitter.cpp')
-rw-r--r--llvm/lib/Target/ARM/ARMCodeEmitter.cpp12
1 files changed, 7 insertions, 5 deletions
diff --git a/llvm/lib/Target/ARM/ARMCodeEmitter.cpp b/llvm/lib/Target/ARM/ARMCodeEmitter.cpp
index 0e932547e9d..7aca1de3878 100644
--- a/llvm/lib/Target/ARM/ARMCodeEmitter.cpp
+++ b/llvm/lib/Target/ARM/ARMCodeEmitter.cpp
@@ -43,16 +43,17 @@ namespace {
const TargetData *TD;
TargetMachine &TM;
MachineCodeEmitter &MCE;
- const MachineConstantPool *MCP;
+ const std::vector<MachineConstantPoolEntry> *MCPEs;
+
public:
static char ID;
explicit ARMCodeEmitter(TargetMachine &tm, MachineCodeEmitter &mce)
: MachineFunctionPass(&ID), JTI(0), II(0), TD(0), TM(tm),
- MCE(mce), MCP(0) {}
+ MCE(mce), MCPEs(0) {}
ARMCodeEmitter(TargetMachine &tm, MachineCodeEmitter &mce,
const ARMInstrInfo &ii, const TargetData &td)
: MachineFunctionPass(&ID), JTI(0), II(&ii), TD(&td), TM(tm),
- MCE(mce), MCP(0) {}
+ MCE(mce), MCPEs(0) {}
bool runOnMachineFunction(MachineFunction &MF);
@@ -153,7 +154,8 @@ bool ARMCodeEmitter::runOnMachineFunction(MachineFunction &MF) {
II = ((ARMTargetMachine&)MF.getTarget()).getInstrInfo();
TD = ((ARMTargetMachine&)MF.getTarget()).getTargetData();
JTI = ((ARMTargetMachine&)MF.getTarget()).getJITInfo();
- MCP = MF.getConstantPool();
+ MCPEs = &MF.getConstantPool()->getConstants();
+ JTI->ResizeConstPoolMap(MCPEs->size());
do {
DOUT << "JITTing function '" << MF.getFunction()->getName() << "'\n";
@@ -264,7 +266,7 @@ void ARMCodeEmitter::emitInstruction(const MachineInstr &MI) {
void ARMCodeEmitter::emitConstPoolInstruction(const MachineInstr &MI) {
unsigned CPI = MI.getOperand(0).getImm();
unsigned CPIndex = MI.getOperand(1).getIndex();
- const MachineConstantPoolEntry &MCPE = MCP->getConstants()[CPIndex];
+ const MachineConstantPoolEntry &MCPE = (*MCPEs)[CPIndex];
// Remember the CONSTPOOL_ENTRY address for later relocation.
JTI->addConstantPoolEntryAddr(CPI, MCE.getCurrentPCValue());
OpenPOWER on IntegriCloud