[llvm] [NVPTX] instcombine known pointer AS checks. (PR #112964)
Alex MacLean via llvm-commits
llvm-commits at lists.llvm.org
Sat Oct 26 10:46:38 PDT 2024
================
@@ -6365,6 +6367,32 @@ static Value *simplifyUnaryIntrinsic(Function *F, Value *Op0,
break;
}
+ case Intrinsic::nvvm_isspacep_global:
+ case Intrinsic::nvvm_isspacep_local:
+ case Intrinsic::nvvm_isspacep_shared:
+ case Intrinsic::nvvm_isspacep_const: {
+ auto *Ty = F->getReturnType();
+ unsigned AS = Op0->getType()->getPointerAddressSpace();
+ if (AS == NVPTXAS::ADDRESS_SPACE_GENERIC) {
+ if (auto *ASC = dyn_cast<AddrSpaceCastInst>(Op0))
+ AS = ASC->getSrcAddressSpace();
+ else if (auto *ASCO = dyn_cast<AddrSpaceCastOperator>(Op0))
+ AS = ASCO->getOperand(0)->getType()->getPointerAddressSpace();
+ }
+ if (AS == NVPTXAS::ADDRESS_SPACE_GENERIC ||
+ AS == NVPTXAS::ADDRESS_SPACE_PARAM)
+ return nullptr; // Got to check at run-time.
+ bool ASMatches = (AS == NVPTXAS::ADDRESS_SPACE_GLOBAL &&
----------------
AlexMaclean wrote:
This seems correct, but I think we can also do some simplification for `nvvm_isspacep_shared_cluster`. If the ptr type is non shared we know this check will return false.
https://github.com/llvm/llvm-project/pull/112964
More information about the llvm-commits
mailing list