diff options
author | Evan Cheng <evan.cheng@apple.com> | 2010-06-20 00:54:38 +0000 |
---|---|---|
committer | Evan Cheng <evan.cheng@apple.com> | 2010-06-20 00:54:38 +0000 |
commit | 884a8fe5fa01f55aa53d9c2b02dbbf0f6c1a5837 (patch) | |
tree | 3ca4de1d66bf4f7ea356e85615832e06437adeb8 /llvm/lib/Target/ARM/Thumb2ITBlockPass.cpp | |
parent | c515ab1eb21a93a7bef36671a7910517b572956d (diff) | |
download | bcm5719-llvm-884a8fe5fa01f55aa53d9c2b02dbbf0f6c1a5837.tar.gz bcm5719-llvm-884a8fe5fa01f55aa53d9c2b02dbbf0f6c1a5837.zip |
Fix a crash caused by dereference of MBB.end(). rdar://8110842
llvm-svn: 106399
Diffstat (limited to 'llvm/lib/Target/ARM/Thumb2ITBlockPass.cpp')
-rw-r--r-- | llvm/lib/Target/ARM/Thumb2ITBlockPass.cpp | 14 |
1 files changed, 8 insertions, 6 deletions
diff --git a/llvm/lib/Target/ARM/Thumb2ITBlockPass.cpp b/llvm/lib/Target/ARM/Thumb2ITBlockPass.cpp index d72bb5d731a..52ab71a71fe 100644 --- a/llvm/lib/Target/ARM/Thumb2ITBlockPass.cpp +++ b/llvm/lib/Target/ARM/Thumb2ITBlockPass.cpp @@ -317,12 +317,14 @@ Thumb2ITBlockPass::MoveCopyOutOfITBlock(MachineInstr *MI, // If not, then there is nothing to be gained by moving the copy. MachineBasicBlock::iterator I = MI; ++I; MachineBasicBlock::iterator E = MI->getParent()->end(); - while (I != E && I->isDebugValue()) - ++I; - unsigned NPredReg = 0; - ARMCC::CondCodes NCC = getPredicate(I, NPredReg); - if (NCC == CC || NCC == OCC) - return true; + if (I != E) { + while (I != E && I->isDebugValue()) + ++I; + unsigned NPredReg = 0; + ARMCC::CondCodes NCC = getPredicate(I, NPredReg); + if (NCC == CC || NCC == OCC) + return true; + } } return false; } |