[llvm] [RISCV][TTI] Add shuffle costing for masked slide lowering (PR #128537)
Philip Reames via llvm-commits
llvm-commits at lists.llvm.org
Thu Feb 27 15:16:52 PST 2025
================
@@ -413,6 +413,36 @@ bool llvm::getShuffleDemandedElts(int SrcWidth, ArrayRef<int> Mask,
return true;
}
+bool llvm::isMaskedSlidePair(ArrayRef<int> Mask, int NumElts,
+ std::array<std::pair<int, int>, 2> &SrcInfo) {
+ const int SignalValue = NumElts * 2;
+ SrcInfo[0] = {-1, SignalValue};
+ SrcInfo[1] = {-1, SignalValue};
----------------
preames wrote:
I went digging a bit further, and SLP is costing length changing shuffles in numerous places. I decide to go with the easy fix here, and just add an explicit guard that avoids costing length changing shuffles with the new lowering.
https://github.com/llvm/llvm-project/pull/128537
More information about the llvm-commits
mailing list