[llvm] [VPlan] Impl VPlan-based pattern match for ExtendedRed and MulAccRed (PR #113903)
Luke Lau via llvm-commits
llvm-commits at lists.llvm.org
Thu Mar 20 02:52:40 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();
----------------
lukel97 wrote:
Yeah, the recurrence kind can be obtained from just the opcode so I think this is fine
https://github.com/llvm/llvm-project/pull/113903
More information about the llvm-commits
mailing list