From 9f13fc7d63a93bc2e4ae9efcc685a49242d57dbb Mon Sep 17 00:00:00 2001 From: Bill Wendling Date: Fri, 11 Dec 2009 10:43:41 +0000 Subject: Revert part of r91101 which was causing an infinite loop in the self-hosting build bots. llvm-svn: 91113 --- llvm/lib/CodeGen/MachineBasicBlock.cpp | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) (limited to 'llvm/lib/CodeGen/MachineBasicBlock.cpp') diff --git a/llvm/lib/CodeGen/MachineBasicBlock.cpp b/llvm/lib/CodeGen/MachineBasicBlock.cpp index 7ce723e..0097dd1 100644 --- a/llvm/lib/CodeGen/MachineBasicBlock.cpp +++ b/llvm/lib/CodeGen/MachineBasicBlock.cpp @@ -457,11 +457,16 @@ MachineBasicBlock::BranchesToLandingPad(const MachineBasicBlock *MBB) const { SmallSet Visited; const MachineBasicBlock *CurMBB = MBB; - while (!CurMBB->isLandingPad()) { - if (CurMBB->succ_size() != 1) + while (!Visited.count(CurMBB) && !CurMBB->isLandingPad()) { + if (CurMBB->size() != 1 || CurMBB->succ_empty() || CurMBB->succ_size() != 1) break; - if (!Visited.insert(CurMBB)) break; + const TargetInstrInfo *TII = + CurMBB->getParent()->getTarget().getInstrInfo(); + if (!TII->isUnpredicatedTerminator(CurMBB->begin())) + break; + + Visited.insert(CurMBB); CurMBB = *CurMBB->succ_begin(); } -- cgit v1.1