diff options
| author | Evan Cheng <evan.cheng@apple.com> | 2008-10-31 19:55:13 +0000 |
|---|---|---|
| committer | Evan Cheng <evan.cheng@apple.com> | 2008-10-31 19:55:13 +0000 |
| commit | 20dbb3bcad3c32330290abef066e1e1465fd2a3f (patch) | |
| tree | 8ccbc7163afa2079672174a81775a856f4075b5e /llvm/lib/Target/ARM/ARMCodeEmitter.cpp | |
| parent | 44994e0c77d31ca95afebcdb3172776c01d23bec (diff) | |
| download | bcm5719-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.cpp | 12 |
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()); |

