[llvm] [LV][EVL] Support fixed-order recurrence idiom with EVL tail folding. (PR #124093)

Luke Lau via llvm-commits llvm-commits at lists.llvm.org
Tue Feb 18 04:01:39 PST 2025


================
@@ -1727,6 +1783,30 @@ static void transformRecipestoEVLRecipes(VPlan &Plan, VPValue &EVL) {
   VPTypeAnalysis TypeInfo(CanonicalIVType);
   LLVMContext &Ctx = CanonicalIVType->getContext();
   VPValue *AllOneMask = Plan.getOrAddLiveIn(ConstantInt::getTrue(Ctx));
+  VPRegionBlock *LoopRegion = Plan.getVectorLoopRegion();
+  VPBasicBlock *Header = LoopRegion->getEntryBasicBlock();
+
+  // Create a scalar phi to track the previous EVL if fixed-order recurrence is
+  // contained.
+  VPScalarPHIRecipe *PrevEVL = nullptr;
+  bool ContainsFORs =
+      any_of(Header->phis(), IsaPred<VPFirstOrderRecurrencePHIRecipe>);
+  if (ContainsFORs) {
+    // TODO: Use VPInstruction::ExplicitVectorLength to get maximum EVL.
----------------
lukel97 wrote:

Oh ok I see how that would work if we change `VPFirstOrderRecurrencePHIRecipe` too to not use getRuntimeVF. 

I think what the current PR has is good so I'll mark this as resolved. I'm not sure about what you mean about the performance though. Would using ExplicitVectorLength instead of VF help performance?

https://github.com/llvm/llvm-project/pull/124093


More information about the llvm-commits mailing list