[llvm] [InferAlignment] Increase alignment in masked load / store instrinsics if known (PR #156057)
Nikita Popov via llvm-commits
llvm-commits at lists.llvm.org
Sat Aug 30 13:52:49 PDT 2025
================
@@ -35,8 +37,39 @@ static bool tryToImproveAlign(
return true;
}
}
- // TODO: Also handle memory intrinsics.
- return false;
+
+ IntrinsicInst *II = dyn_cast<IntrinsicInst>(I);
+ if (!II)
+ return false;
+
+ // TODO: Handle more memory intrinsics.
+ switch (II->getIntrinsicID()) {
+ case Intrinsic::masked_load:
+ case Intrinsic::masked_store: {
+ Value *PtrOp = II->getIntrinsicID() == Intrinsic::masked_load
+ ? II->getArgOperand(0)
+ : II->getArgOperand(1);
+ Value *AlignOp = II->getIntrinsicID() == Intrinsic::masked_load
+ ? II->getArgOperand(1)
+ : II->getArgOperand(2);
+
+ Align OldAlign = cast<ConstantInt>(AlignOp)->getAlignValue();
+ Align PrefAlign = getKnownAlignment(PtrOp, DL, II);
+ Align NewAlign = Fn(PtrOp, OldAlign, PrefAlign);
+ if (NewAlign <= OldAlign)
+ return false;
+
+ Value *V = llvm::ConstantInt::get(llvm::Type::getInt32Ty(II->getContext()),
----------------
nikic wrote:
```suggestion
Value *V = ConstantInt::get(llvm::Type::getInt32Ty(II->getContext()),
```
https://github.com/llvm/llvm-project/pull/156057
More information about the llvm-commits
mailing list