From: Chris Lattner Date: Mon, 13 Dec 2010 06:36:51 +0000 (+0000) Subject: make this logic a bit simpler. X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=021c9d3bd41bc446ef0860c05a073e32afa5e20f;p=oota-llvm.git make this logic a bit simpler. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@121689 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Transforms/Utils/SimplifyCFG.cpp b/lib/Transforms/Utils/SimplifyCFG.cpp index e1c9611f9d2..503e5bcb23f 100644 --- a/lib/Transforms/Utils/SimplifyCFG.cpp +++ b/lib/Transforms/Utils/SimplifyCFG.cpp @@ -2200,7 +2200,7 @@ bool SimplifyCFGOpt::SimplifySwitch(SwitchInst *SI) { // see if that predecessor totally determines the outcome of this switch. if (BasicBlock *OnlyPred = BB->getSinglePredecessor()) if (SimplifyEqualityComparisonWithOnlyPredecessor(SI, OnlyPred)) - return SimplifyCFG(BB) || 1; + return SimplifyCFG(BB) | true; // If the block only contains the switch, see if we can fold the block // away into any preds. @@ -2210,7 +2210,7 @@ bool SimplifyCFGOpt::SimplifySwitch(SwitchInst *SI) { ++BBI; if (SI == &*BBI) if (FoldValueComparisonIntoPredecessors(SI)) - return SimplifyCFG(BB) || 1; + return SimplifyCFG(BB) | true; return false; } @@ -2397,27 +2397,26 @@ bool SimplifyCFGOpt::run(BasicBlock *BB) { Changed |= FoldTwoEntryPHINode(PN); if (BranchInst *BI = dyn_cast(BB->getTerminator())) { - if (BI->isUnconditional()) - return SimplifyUncondBranch(BI) | Changed; - - return SimplifyCondBranch(BI) | Changed; + if (BI->isUnconditional()) { + if (SimplifyUncondBranch(BI)) return true; + } else { + if (SimplifyCondBranch(BI)) + return true; + } + } else if (ReturnInst *RI = dyn_cast(BB->getTerminator())) { + if (SimplifyReturn(RI)) return true; + } else if (SwitchInst *SI = dyn_cast(BB->getTerminator())) { + if (SimplifySwitch(SI)) return true; + } else if (UnreachableInst *UI = + dyn_cast(BB->getTerminator())) { + if (SimplifyUnreachable(UI)) return true; + } else if (UnwindInst *UI = dyn_cast(BB->getTerminator())) { + if (SimplifyUnwind(UI)) return true; + } else if (IndirectBrInst *IBI = + dyn_cast(BB->getTerminator())) { + if (SimplifyIndirectBr(IBI)) return true; } - if (ReturnInst *RI = dyn_cast(BB->getTerminator())) - return SimplifyReturn(RI) | Changed; - - if (SwitchInst *SI = dyn_cast(BB->getTerminator())) - return SimplifySwitch(SI) | Changed; - - if (UnreachableInst *UI = dyn_cast(BB->getTerminator())) - return SimplifyUnreachable(UI) | Changed; - - if (UnwindInst *UI = dyn_cast(BB->getTerminator())) - return SimplifyUnwind(UI) | Changed; - - if (IndirectBrInst *IBI = dyn_cast(BB->getTerminator())) - return SimplifyIndirectBr(IBI) | Changed; - return Changed; }