[llvm] [JumpThreading] Copy metadata when inserting preload into preds (PR #134403)
Nikita Popov via llvm-commits
llvm-commits at lists.llvm.org
Sun Apr 13 09:09:34 PDT 2025
================
@@ -1409,6 +1409,13 @@ bool JumpThreadingPass::simplifyPartiallyRedundantLoad(LoadInst *LoadI) {
if (AATags)
NewVal->setAAMetadata(AATags);
+ if (auto *MD = LoadI->getMetadata(LLVMContext::MD_invariant_load))
+ NewVal->setMetadata(LLVMContext::MD_invariant_load, MD);
+ if (auto *InvGroupMD = LoadI->getMetadata(LLVMContext::MD_invariant_group))
+ NewVal->setMetadata(LLVMContext::MD_invariant_group, InvGroupMD);
+ if (auto *RangeMD = LoadI->getMetadata(LLVMContext::MD_range))
+ NewVal->setMetadata(LLVMContext::MD_range, RangeMD);
----------------
nikic wrote:
Can we copy all metadata and then call dropUBImplyingAttrsAndMetadata()? We could only call it for the !isGuaranteedToTransferExecutionToSuccessor case.
I don't think preserving invariant_load is valid for the non-guaranteed-to-transfer case, at least with the currently specified semantics.
https://github.com/llvm/llvm-project/pull/134403
More information about the llvm-commits
mailing list