[llvm] [AArch64][SME] Enable dynamic shuffle for fixed length types. (PR #72490)
Sam Tebbs via llvm-commits
llvm-commits at lists.llvm.org
Mon Dec 18 06:37:57 PST 2023
================
@@ -26123,26 +26123,48 @@ static SDValue GenerateFixedLengthSVETBL(SDValue Op, SDValue Op1, SDValue Op2,
// Ignore two operands if no SVE2 or all index numbers couldn't
// be represented.
- if (!IsSingleOp && (!Subtarget.hasSVE2() || MinSVESize != MaxSVESize))
+ if (!IsSingleOp && !Subtarget.hasSVE2())
return SDValue();
EVT VTOp1 = Op.getOperand(0).getValueType();
unsigned BitsPerElt = VTOp1.getVectorElementType().getSizeInBits();
unsigned IndexLen = MinSVESize / BitsPerElt;
unsigned ElementsPerVectorReg = VTOp1.getVectorNumElements();
uint64_t MaxOffset = APInt(BitsPerElt, -1, false).getZExtValue();
+ EVT MaskEltType = EVT::getIntegerVT(*DAG.getContext(), BitsPerElt);
----------------
SamTebbs33 wrote:
If `BitsPerElt` comes from `VTOp1.getVectorElementType()`, then can `MaskEltType` just be set to `VTOp1.getVectorElementType()`?
https://github.com/llvm/llvm-project/pull/72490
More information about the llvm-commits
mailing list