diff options
author | Cameron Zwarich <zwarich@apple.com> | 2010-12-28 10:49:33 +0000 |
---|---|---|
committer | Cameron Zwarich <zwarich@apple.com> | 2010-12-28 10:49:33 +0000 |
commit | 92f6e4290ca29338c8e79f6ef2d76928d8798d3c (patch) | |
tree | a016eabdbc379e326ef834b964a7a988f4b8a5e8 /llvm/lib/CodeGen/StrongPHIElimination.cpp | |
parent | 496770debc1681bfd8518d1f3d58611dce8b7a63 (diff) | |
download | bcm5719-llvm-92f6e4290ca29338c8e79f6ef2d76928d8798d3c.tar.gz bcm5719-llvm-92f6e4290ca29338c8e79f6ef2d76928d8798d3c.zip |
Avoid iterating every operand of an instruction in StrongPHIElimination, since
we are only interested in the defs when discovering interferences.
This is a 28% speedup running StrongPHIElimination on 403.gcc.
llvm-svn: 122596
Diffstat (limited to 'llvm/lib/CodeGen/StrongPHIElimination.cpp')
-rw-r--r-- | llvm/lib/CodeGen/StrongPHIElimination.cpp | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/llvm/lib/CodeGen/StrongPHIElimination.cpp b/llvm/lib/CodeGen/StrongPHIElimination.cpp index c1a76a6193a..f84fdbe5bc2 100644 --- a/llvm/lib/CodeGen/StrongPHIElimination.cpp +++ b/llvm/lib/CodeGen/StrongPHIElimination.cpp @@ -471,10 +471,9 @@ StrongPHIElimination::SplitInterferencesForBasicBlock( DenseMap<unsigned, unsigned>& ImmediateDominatingParent) { for (MachineBasicBlock::iterator BBI = MBB.begin(), BBE = MBB.end(); BBI != BBE; ++BBI) { - for (unsigned i = 0, e = BBI->getNumOperands(); i != e; ++i) { - MachineOperand& MO = BBI->getOperand(i); - if (!MO.isReg() || !MO.isDef()) - continue; + for (MachineInstr::const_mop_iterator I = BBI->operands_begin(), + E = BBI->operands_end(); I != E && I->isReg() && I->isDef(); ++I) { + const MachineOperand& MO = *I; unsigned DestReg = MO.getReg(); if (!DestReg || !TargetRegisterInfo::isVirtualRegister(DestReg)) |