[llvm] [DebugInfo] Handle additional types of stores in assignment tracking (PR #129070)
Alex Bradbury via llvm-commits
llvm-commits at lists.llvm.org
Tue Mar 4 21:38:27 PST 2025
================
@@ -4956,8 +4956,19 @@ void Verifier::visitProfMetadata(Instruction &I, MDNode *MD) {
void Verifier::visitDIAssignIDMetadata(Instruction &I, MDNode *MD) {
assert(I.hasMetadata(LLVMContext::MD_DIAssignID));
- bool ExpectedInstTy =
- isa<AllocaInst>(I) || isa<StoreInst>(I) || isa<MemIntrinsic>(I);
+ // DIAssignID metadata must be attached to either an alloca or some form of
+ // store/memory-writing instruction.
+ // FIXME: Is there any simpler way to express this property than manually
+ // enumerating all instructions that could perform an assignment?
+ bool ExpectedInstTy = isa<AllocaInst>(I) || isa<StoreInst>(I);
+ if (auto *II = dyn_cast<IntrinsicInst>(&I)) {
+ const static Intrinsic::ID StoreIntrinsics[] = {
+ Intrinsic::vp_store, Intrinsic::vp_scatter,
+ Intrinsic::experimental_vp_strided_store, Intrinsic::masked_store,
+ Intrinsic::masked_scatter};
----------------
asb wrote:
Perhaps llvm.masked.compress_store be included here as well?
https://github.com/llvm/llvm-project/pull/129070
More information about the llvm-commits
mailing list