[llvm] [Attributor] Propagate alignment through ptrmask (PR #150158)

Matt Arsenault via llvm-commits llvm-commits at lists.llvm.org
Mon Aug 11 21:53:20 PDT 2025


================
@@ -5188,6 +5188,81 @@ struct AADereferenceableCallSiteReturned final
 // ------------------------ Align Argument Attribute ------------------------
 
 namespace {
+
+Align getKnownAlignForIntrinsic(Attributor &A, AAAlign &QueryingAA,
+                                const IntrinsicInst *II) {
+  switch (II->getIntrinsicID()) {
+  case Intrinsic::ptrmask: {
+    const auto *ConstVals = A.getAAFor<AAPotentialConstantValues>(
+        QueryingAA, IRPosition::value(*(II->getOperand(1))), DepClassTy::NONE);
----------------
arsenm wrote:

I mean AAAlign would use AAPotentialConstantValues, not you need to perform an additional alignment analysis if the value happens to be constant 

https://github.com/llvm/llvm-project/pull/150158


More information about the llvm-commits mailing list