diff options
author | Gil Rapaport <gil.rapaport@intel.com> | 2017-04-25 05:57:22 +0000 |
---|---|---|
committer | Gil Rapaport <gil.rapaport@intel.com> | 2017-04-25 05:57:22 +0000 |
commit | 860f0a2bad922b81591ccc6de8a86f9ecb286ecb (patch) | |
tree | a29ff1a006fa40da74dcd2fdc67dc69f0837347f /llvm/lib/Transforms/Vectorize/LoopVectorize.cpp | |
parent | 376508ad8d61bd507ddc5f904bb7d8a3c461e4b7 (diff) | |
download | bcm5719-llvm-860f0a2bad922b81591ccc6de8a86f9ecb286ecb.tar.gz bcm5719-llvm-860f0a2bad922b81591ccc6de8a86f9ecb286ecb.zip |
[LV] Remove redundant basic block split
This patch is part of D28975's breakdown.
Genreating the control-flow to guard predicated instructions modified to
only use SplitBlockAndInsertIfThen() for producing the if-then construct.
Differential Revision: https://reviews.llvm.org/D32224
llvm-svn: 301293
Diffstat (limited to 'llvm/lib/Transforms/Vectorize/LoopVectorize.cpp')
-rw-r--r-- | llvm/lib/Transforms/Vectorize/LoopVectorize.cpp | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/llvm/lib/Transforms/Vectorize/LoopVectorize.cpp b/llvm/lib/Transforms/Vectorize/LoopVectorize.cpp index bc7c54dc4a3..30f739934bb 100644 --- a/llvm/lib/Transforms/Vectorize/LoopVectorize.cpp +++ b/llvm/lib/Transforms/Vectorize/LoopVectorize.cpp @@ -4516,14 +4516,15 @@ void InnerLoopVectorizer::predicateInstructions() { for (auto KV : PredicatedInstructions) { BasicBlock::iterator I(KV.first); BasicBlock *Head = I->getParent(); - auto *BB = SplitBlock(Head, &*std::next(I), DT, LI); auto *T = SplitBlockAndInsertIfThen(KV.second, &*I, /*Unreachable=*/false, /*BranchWeights=*/nullptr, DT, LI); I->moveBefore(T); sinkScalarOperands(&*I); - I->getParent()->setName(Twine("pred.") + I->getOpcodeName() + ".if"); - BB->setName(Twine("pred.") + I->getOpcodeName() + ".continue"); + BasicBlock *PredicatedBlock = I->getParent(); + Twine BBNamePrefix = Twine("pred.") + I->getOpcodeName(); + PredicatedBlock->setName(BBNamePrefix + ".if"); + PredicatedBlock->getSingleSuccessor()->setName(BBNamePrefix + ".continue"); // If the instruction is non-void create a Phi node at reconvergence point. if (!I->getType()->isVoidTy()) { |