[llvm] [VPlan] Update scalar induction resume values in VPlan. (PR #110577)
via llvm-commits
llvm-commits at lists.llvm.org
Thu Dec 5 13:36:43 PST 2024
================
@@ -2580,16 +2605,17 @@ void InnerLoopVectorizer::createVectorLoopSkeleton(StringRef Prefix) {
nullptr, Twine(Prefix) + "scalar.ph");
}
-PHINode *InnerLoopVectorizer::createInductionResumeValue(
- PHINode *OrigPhi, const InductionDescriptor &II, Value *Step,
- ArrayRef<BasicBlock *> BypassBlocks,
- std::pair<BasicBlock *, Value *> AdditionalBypass) {
+void InnerLoopVectorizer::createInductionResumeVPValue(
+ VPIRInstruction *InductionPhiRI, const InductionDescriptor &II, Value *Step,
+ ArrayRef<BasicBlock *> BypassBlocks, VPBuilder &ScalarPHBuilder,
+ Value *AdditionalBypassValue) {
+ auto *OrigPhi = cast<PHINode>(&InductionPhiRI->getInstruction());
Value *VectorTripCount = getOrCreateVectorTripCount(LoopVectorPreHeader);
assert(VectorTripCount && "Expected valid arguments");
Instruction *OldInduction = Legal->getPrimaryInduction();
Value *EndValue = nullptr;
- Value *EndValueFromAdditionalBypass = AdditionalBypass.second;
+ Value *EndValueFromAdditionalBypass = AdditionalBypassValue;
if (OrigPhi == OldInduction) {
// We know what the end value is.
EndValue = VectorTripCount;
----------------
ayalz wrote:
```suggestion
Value *EndValueFromAdditionalBypass = MainVectorTripCount;
// Otherwise compute them accordingly.
if (OrigPhi != OldInduction) {
```
https://github.com/llvm/llvm-project/pull/110577
More information about the llvm-commits
mailing list