[llvm] [VPlan] Impl VPlan-based pattern match for ExtendedRed and MulAccRed (PR #113903)
Florian Hahn via llvm-commits
llvm-commits at lists.llvm.org
Wed Mar 19 09:12:52 PDT 2025
================
@@ -2185,6 +2273,172 @@ void VPlanTransforms::handleUncountableEarlyExit(
LatchExitingBranch->eraseFromParent();
}
+/// This function tries to match following pattern to create
+/// VPExtendedReductionRecipe and clamp the \p Range if it is beneficial and
+/// valid. The created VPExtendedReductionRecipe will lower to concrete recipes
+/// before execution.
+/// reduce(ext(...)).
+static VPExtendedReductionRecipe *
+tryToMatchAndCreateExtendedReduction(VPReductionRecipe *Red, VPCostContext &Ctx,
+ VFRange &Range) {
+ using namespace VPlanPatternMatch;
+
+ Type *RedTy = Ctx.Types.inferScalarType(Red);
+ VPValue *VecOp = Red->getVecOp();
+ const RecurrenceDescriptor &RdxDesc = Red->getRecurrenceDescriptor();
----------------
fhahn wrote:
Does this need anything from RdxDesc other than the info retained in @lukel97 's https://github.com/llvm/llvm-project/pull/131300
https://github.com/llvm/llvm-project/pull/113903
More information about the llvm-commits
mailing list