Simplify check that optional def is there and is CPSR.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141602 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Bill Wendling 2011-10-11 00:10:41 +00:00
parent bb5b3f3359
commit 3f56d4b957

View File

@ -140,11 +140,10 @@ Thumb2ITBlockPass::MoveCopyOutOfITBlock(MachineInstr *MI,
// rsb r1, 0
// rsb r2, 0
//
//
for (unsigned I = 0, E = MI->getNumOperands(); I != E; ++I)
if (MI->getOperand(I).isReg() && MI->getOperand(I).getReg() == ARM::CPSR &&
MI->getOperand(I).isDef())
return false;
const MCInstrDesc &MCID = MI->getDesc();
if (MCID.hasOptionalDef() &&
MI->getOperand(MCID.getNumOperands() - 1).getReg() == ARM::CPSR)
return false;
// Then peek at the next instruction to see if it's predicated on CC or OCC.
// If not, then there is nothing to be gained by moving the copy.