From 117f8cffc5499217ff8824eb0d6a0f6b1b78d96e Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Tue, 14 Dec 2010 05:57:30 +0000 Subject: [PATCH] reapply my recent change that disables a piece of the switch formation work, but fixes 400.perlbmk. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@121749 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Transforms/Utils/SimplifyCFG.cpp | 18 +++++++++++++----- test/Transforms/SimplifyCFG/switch_create.ll | 3 +-- 2 files changed, 14 insertions(+), 7 deletions(-) diff --git a/lib/Transforms/Utils/SimplifyCFG.cpp b/lib/Transforms/Utils/SimplifyCFG.cpp index ca690e7f870..15e487c70c3 100644 --- a/lib/Transforms/Utils/SimplifyCFG.cpp +++ b/lib/Transforms/Utils/SimplifyCFG.cpp @@ -1515,7 +1515,7 @@ bool llvm::FoldBranchToCommonDest(BranchInst *BI) { AddPredecessorToBlock(FalseDest, PredBlock, BB); PBI->setSuccessor(1, FalseDest); } - return SimplifyCFG(PBI->getParent()) | true; + return true; } return false; } @@ -1905,17 +1905,25 @@ static bool SimplifyBranchOnICmpChain(BranchInst *BI, const TargetData *TD) { BasicBlock *BB = BI->getParent(); + DEBUG(dbgs() << "CONVERTING 'icmp' CHAIN with " << Values.size() + << " cases into SWITCH. BB is:\n" << *BB); + // If there are any extra values that couldn't be folded into the switch // then we evaluate them with an explicit branch first. Split the block // right before the condbr to handle it. if (ExtraCase) { - return false; + DEBUG(dbgs() << " ** 'icmp' chain unhandled condition: " << *ExtraCase + << '\n'); BasicBlock *NewBB = BB->splitBasicBlock(BI, "switch.early.test"); // Remove the uncond branch added to the old block. TerminatorInst *OldTI = BB->getTerminator(); - BranchInst::Create(EdgeBB, NewBB, ExtraCase, OldTI); + if (TrueWhenEqual) + BranchInst::Create(EdgeBB, NewBB, ExtraCase, OldTI); + else + BranchInst::Create(NewBB, EdgeBB, ExtraCase, OldTI); + OldTI->eraseFromParent(); // If there are PHI nodes in EdgeBB, then we need to add a new entry to them @@ -1955,6 +1963,7 @@ static bool SimplifyBranchOnICmpChain(BranchInst *BI, const TargetData *TD) { // Erase the old branch instruction. EraseTerminatorInstAndDCECond(BI); + return true; } @@ -2410,8 +2419,7 @@ bool SimplifyCFGOpt::run(BasicBlock *BB) { if (BI->isUnconditional()) { if (SimplifyUncondBranch(BI)) return true; } else { - if (SimplifyCondBranch(BI)) - return true; + if (SimplifyCondBranch(BI)) return true; } } else if (ReturnInst *RI = dyn_cast(BB->getTerminator())) { if (SimplifyReturn(RI)) return true; diff --git a/test/Transforms/SimplifyCFG/switch_create.ll b/test/Transforms/SimplifyCFG/switch_create.ll index 71007b9efaf..a49f782277d 100644 --- a/test/Transforms/SimplifyCFG/switch_create.ll +++ b/test/Transforms/SimplifyCFG/switch_create.ll @@ -1,5 +1,4 @@ ; RUN: opt < %s -simplifycfg -S | FileCheck %s -; XFAIL: * declare void @foo1() @@ -257,7 +256,7 @@ lor.end: ; preds = %lor.rhs, %lor.lhs.f ; HECK: %cmp = icmp ult i8 %c, 33 ; HECK: br i1 %cmp, label %lor.end, label %switch.early.test -; HECK: switch.early.test: +; CHECK: switch.early.test: ; HECK: switch i8 %c, label %lor.rhs [ ; HECK: i8 46, label %lor.end ; HECK: i8 44, label %lor.end