[llvm] [DA] do not handle array accesses of different offsets (PR #123436)
Michael Kruse via llvm-commits
llvm-commits at lists.llvm.org
Wed Feb 26 07:17:41 PST 2025
================
@@ -3649,6 +3646,111 @@ DependenceInfo::depends(Instruction *Src, Instruction *Dst) {
LLVM_DEBUG(dbgs() << "can't analyze SCEV with different pointer base\n");
return std::make_unique<Dependence>(Src, Dst);
}
+
+ auto EltSize = SrcLoc.Size.toRaw();
+ assert(EltSize == DstLoc.Size.toRaw() && "Array element size differ");
+
+ // Check that memory access offsets in V are multiples of array EltSize.
+ std::function<bool(const SCEV *, const SCEV *&)> checkOffsets =
+ [&](const SCEV *V, const SCEV *&Param) -> bool {
+ if (auto *AddRec = dyn_cast<SCEVAddRecExpr>(V)) {
+ if (!checkOffsets(AddRec->getStart(), Param))
----------------
Meinersbur wrote:
For recusive calls, I'd avoid lambdas. The necessary cast to `std::function` causes a lot of overhead that is unlikely to be optimized aways.
https://github.com/llvm/llvm-project/pull/123436
More information about the llvm-commits
mailing list