summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen/PrologEpilogInserter.cpp
diff options
context:
space:
mode:
authorJim Grosbach <grosbach@apple.com>2009-10-14 21:22:39 +0000
committerJim Grosbach <grosbach@apple.com>2009-10-14 21:22:39 +0000
commitb1d6fde13e529e7a5217e2b7c48c0437cea9dee5 (patch)
treeb46050b31d901784d12158cc08a80dada2d420b7 /llvm/lib/CodeGen/PrologEpilogInserter.cpp
parent6875c5ebe49f63485dd43ca96402e1af52f14b02 (diff)
downloadbcm5719-llvm-b1d6fde13e529e7a5217e2b7c48c0437cea9dee5.tar.gz
bcm5719-llvm-b1d6fde13e529e7a5217e2b7c48c0437cea9dee5.zip
Make loop not recalc getNumOperands() each time around
llvm-svn: 84138
Diffstat (limited to 'llvm/lib/CodeGen/PrologEpilogInserter.cpp')
-rw-r--r--llvm/lib/CodeGen/PrologEpilogInserter.cpp5
1 files changed, 2 insertions, 3 deletions
diff --git a/llvm/lib/CodeGen/PrologEpilogInserter.cpp b/llvm/lib/CodeGen/PrologEpilogInserter.cpp
index 74cc18b9155..7af0bba1973 100644
--- a/llvm/lib/CodeGen/PrologEpilogInserter.cpp
+++ b/llvm/lib/CodeGen/PrologEpilogInserter.cpp
@@ -778,9 +778,7 @@ void PEI::scavengeFrameVirtualRegs(MachineFunction &Fn) {
// directly.
for (MachineBasicBlock::iterator I = BB->begin(); I != BB->end(); ++I) {
MachineInstr *MI = I;
- // Likewise, call getNumOperands() each iteration, as the MI may change
- // inside the loop (with 'i' updated accordingly).
- for (unsigned i = 0; i != MI->getNumOperands(); ++i)
+ for (unsigned i = 0, e = MI->getNumOperands(); i != e; ++i)
if (MI->getOperand(i).isReg()) {
MachineOperand &MO = MI->getOperand(i);
unsigned Reg = MO.getReg();
@@ -853,6 +851,7 @@ void PEI::scavengeFrameVirtualRegs(MachineFunction &Fn) {
// just calculating the value we already have.
BB->erase(I, LastUseMI);
MI = I = LastUseMI;
+ e = MI->getNumOperands();
CurrentScratchReg = PrevScratchReg;
// Extend the live range of the register
OpenPOWER on IntegriCloud