[llvm] clastb representation in existing IR, and AArch64 codegen (PR #112738)
Matt Arsenault via llvm-commits
llvm-commits at lists.llvm.org
Wed Feb 5 06:59:49 PST 2025
================
@@ -19944,6 +19945,28 @@ performLastTrueTestVectorCombine(SDNode *N,
return getPTest(DAG, N->getValueType(0), Pg, N0, AArch64CC::LAST_ACTIVE);
}
+static SDValue
+performExtractLastActiveCombine(SDNode *N, TargetLowering::DAGCombinerInfo &DCI,
+ const AArch64Subtarget *Subtarget) {
+ assert(N->getOpcode() == ISD::EXTRACT_VECTOR_ELT);
+ SelectionDAG &DAG = DCI.DAG;
+ SDValue Vec = N->getOperand(0);
+ SDValue Idx = N->getOperand(1);
+
+ if (!Subtarget->hasSVE() || DCI.isBeforeLegalize() ||
+ Idx.getOpcode() != ISD::VECTOR_FIND_LAST_ACTIVE)
+ return SDValue();
+
+ SDValue Mask = Idx.getOperand(0);
+ const TargetLowering &TLI = DAG.getTargetLoweringInfo();
+ if (TLI.getOperationAction(ISD::VECTOR_FIND_LAST_ACTIVE,
+ Mask.getValueType()) != TargetLowering::Legal)
----------------
arsenm wrote:
isOperationLegal?
https://github.com/llvm/llvm-project/pull/112738
More information about the llvm-commits
mailing list