[llvm] Calculate KnownBits from Metadata correctly for vector loads (PR #128908)
via llvm-commits
llvm-commits at lists.llvm.org
Tue Mar 11 11:16:08 PDT 2025
================
@@ -4116,9 +4119,24 @@ SDValue AMDGPUTargetLowering::performShlCombine(SDNode *N,
SDValue NewShift =
DAG.getNode(ISD::SHL, SL, TargetType, Lo, ShiftAmt, N->getFlags());
- const SDValue Zero = DAG.getConstant(0, SL, TargetType);
-
- SDValue Vec = DAG.getBuildVector(TargetVecPairType, SL, {Zero, NewShift});
+ const SDValue Zero = DAG.getConstant(0, SL, TargetScalarType);
+ SDValue Vec;
+
+ if (VT.isVector()) {
+ EVT ConcatType = TargetType.getDoubleNumVectorElementsVT(*DAG.getContext());
+ SmallVector<SDValue, 8> Ops;
+ for (unsigned I = 0, E = TargetType.getVectorNumElements(); I != E; ++I) {
----------------
LU-JOHN wrote:
Will update in separate PR for AMDGPU.
https://github.com/llvm/llvm-project/pull/128908
More information about the llvm-commits
mailing list