diff options
author | Jim Grosbach <grosbach@apple.com> | 2009-10-14 21:22:39 +0000 |
---|---|---|
committer | Jim Grosbach <grosbach@apple.com> | 2009-10-14 21:22:39 +0000 |
commit | b1d6fde13e529e7a5217e2b7c48c0437cea9dee5 (patch) | |
tree | b46050b31d901784d12158cc08a80dada2d420b7 /llvm/lib/CodeGen/PrologEpilogInserter.cpp | |
parent | 6875c5ebe49f63485dd43ca96402e1af52f14b02 (diff) | |
download | bcm5719-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.cpp | 5 |
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 |