[llvm] [GVN] Teach GVN simple masked load/store forwarding (PR #157689)
David Sherwood via llvm-commits
llvm-commits at lists.llvm.org
Thu Sep 18 06:37:40 PDT 2025
================
@@ -2287,6 +2288,46 @@ bool GVNPass::processLoad(LoadInst *L) {
return true;
}
+// Attempt to process masked loads which have loaded from
+// masked stores with the same mask
+bool GVNPass::processMaskedLoad(IntrinsicInst *I) {
+ Value *Mask = I->getOperand(2);
+ Value *Passthrough = I->getOperand(3);
+
+ MemDepResult Dep = MD->getDependency(I);
+ Instruction *DepInst = Dep.getInst();
+ if (!DepInst || !Dep.isLocal())
+ return false;
+
+ Value *StoreVal;
+ if (!match(DepInst,
+ m_Intrinsic<Intrinsic::masked_store>(m_Value(StoreVal), m_Value(),
+ m_Value(), m_Specific(Mask))))
+ return false;
+
----------------
david-arm wrote:
If a dependency is local then it's either a Clobber or a Def, and it looks like the code below is assuming a Def. Would be good to clarify this. If so, I think you have to bail out for the clobber case as that's more complicated - see AnalyzeLoadAvailability.
https://github.com/llvm/llvm-project/pull/157689
More information about the llvm-commits
mailing list