forked from OSchip/llvm-project
[LV] Ensure WidenCanonicalIVRecipe is always created in header (NFC).
The VPWidenCanonicalIVRecipe must always be created in the phi section of the header block. Use that block as insert point.
This commit is contained in:
parent
8dbc7745e5
commit
1a54889f48
|
@ -8446,11 +8446,6 @@ VPValue *VPRecipeBuilder::createBlockInMask(BasicBlock *BB, VPlanPtr &Plan) {
|
||||||
if (!CM.blockNeedsPredicationForAnyReason(BB))
|
if (!CM.blockNeedsPredicationForAnyReason(BB))
|
||||||
return BlockMaskCache[BB] = BlockMask; // Loop incoming mask is all-one.
|
return BlockMaskCache[BB] = BlockMask; // Loop incoming mask is all-one.
|
||||||
|
|
||||||
// Create the block in mask as the first non-phi instruction in the block.
|
|
||||||
VPBuilder::InsertPointGuard Guard(Builder);
|
|
||||||
auto NewInsertionPoint = Builder.getInsertBlock()->getFirstNonPhi();
|
|
||||||
Builder.setInsertPoint(Builder.getInsertBlock(), NewInsertionPoint);
|
|
||||||
|
|
||||||
// Introduce the early-exit compare IV <= BTC to form header block mask.
|
// Introduce the early-exit compare IV <= BTC to form header block mask.
|
||||||
// This is used instead of IV < TC because TC may wrap, unlike BTC.
|
// This is used instead of IV < TC because TC may wrap, unlike BTC.
|
||||||
// Start by constructing the desired canonical IV.
|
// Start by constructing the desired canonical IV.
|
||||||
|
@ -8458,10 +8453,17 @@ VPValue *VPRecipeBuilder::createBlockInMask(BasicBlock *BB, VPlanPtr &Plan) {
|
||||||
if (Legal->getPrimaryInduction())
|
if (Legal->getPrimaryInduction())
|
||||||
IV = Plan->getOrAddVPValue(Legal->getPrimaryInduction());
|
IV = Plan->getOrAddVPValue(Legal->getPrimaryInduction());
|
||||||
else {
|
else {
|
||||||
|
VPBasicBlock *HeaderVPBB = Plan->getEntry()->getEntryBasicBlock();
|
||||||
auto *IVRecipe = new VPWidenCanonicalIVRecipe();
|
auto *IVRecipe = new VPWidenCanonicalIVRecipe();
|
||||||
Builder.getInsertBlock()->insert(IVRecipe, NewInsertionPoint);
|
HeaderVPBB->insert(IVRecipe, HeaderVPBB->getFirstNonPhi());
|
||||||
IV = IVRecipe;
|
IV = IVRecipe;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Create the block in mask as the first non-phi instruction in the block.
|
||||||
|
VPBuilder::InsertPointGuard Guard(Builder);
|
||||||
|
auto NewInsertionPoint = Builder.getInsertBlock()->getFirstNonPhi();
|
||||||
|
Builder.setInsertPoint(Builder.getInsertBlock(), NewInsertionPoint);
|
||||||
|
|
||||||
VPValue *BTC = Plan->getOrCreateBackedgeTakenCount();
|
VPValue *BTC = Plan->getOrCreateBackedgeTakenCount();
|
||||||
bool TailFolded = !CM.isScalarEpilogueAllowed();
|
bool TailFolded = !CM.isScalarEpilogueAllowed();
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue