[llvm] [X86] combineConcatVectorOps - concat(shuffle(x,y,m1),shuffle(x,y,m2)) -> shuffle(concat(x,x),concat(y,y),m3) on VBMI targets (PR #130134)
Phoebe Wang via llvm-commits
llvm-commits at lists.llvm.org
Thu Mar 6 23:13:03 PST 2025
================
@@ -57948,9 +57948,14 @@ static SDValue combineConcatVectorOps(const SDLoc &DL, MVT VT,
switch (Op0.getOpcode()) {
case ISD::VECTOR_SHUFFLE: {
- if (NumOps == 2 && VT.is256BitVector() &&
+ // TODO: Relax VBMI requirement for repeated shuffle ops - currently
+ // limited to targets that should always have good cross lane shuffles.
+ if (!IsSplat && NumOps == 2 && VT.is256BitVector() &&
(EltSizeInBits >= 32 || Subtarget.hasInt256()) &&
- (IsConcatFree(VT, Ops, 0) || IsConcatFree(VT, Ops, 1))) {
+ (IsConcatFree(VT, Ops, 0) || IsConcatFree(VT, Ops, 1) ||
+ (Ops[0].getOperand(0) == Ops[1].getOperand(0) &&
+ Ops[0].getOperand(1) == Ops[1].getOperand(1) &&
----------------
phoebewang wrote:
How do we know `Ops[1]` is VECTOR_SHUFFLE?
https://github.com/llvm/llvm-project/pull/130134
More information about the llvm-commits
mailing list