[Mlir-commits] [mlir] [MLIR] Fix use-after-scope when interchanging ploops (PR #196076)
llvmlistbot at llvm.org
llvmlistbot at llvm.org
Wed May 6 06:50:33 PDT 2026
llvmorg-github-actions[bot] wrote:
<!--LLVM PR SUMMARY COMMENT-->
@llvm/pr-subscribers-mlir-scf
Author: Benjamin Kramer (d0k)
<details>
<summary>Changes</summary>
getInductionVars returns a SmallVector, so going through zip+reverse gets us a dangling reference. Quite a footgun.
Found by asan.
---
Full diff: https://github.com/llvm/llvm-project/pull/196076.diff
1 Files Affected:
- (modified) mlir/lib/Dialect/SCF/Transforms/ParallelLoopFusion.cpp (+3-2)
``````````diff
diff --git a/mlir/lib/Dialect/SCF/Transforms/ParallelLoopFusion.cpp b/mlir/lib/Dialect/SCF/Transforms/ParallelLoopFusion.cpp
index cbbe45a00163f..bdaade59e99df 100644
--- a/mlir/lib/Dialect/SCF/Transforms/ParallelLoopFusion.cpp
+++ b/mlir/lib/Dialect/SCF/Transforms/ParallelLoopFusion.cpp
@@ -748,8 +748,9 @@ static std::optional<ParallelOp> interchangeLoops(OpBuilder &builder,
loop.getUpperBound(), loop.getStep(),
loop.getInitVals(), nullptr);
IRMapping mapping;
- for (auto [iv, riv] : llvm::zip(loop.getInductionVars(),
- llvm::reverse(newOp.getInductionVars()))) {
+ auto ivs = loop.getInductionVars();
+ auto newIvs = newOp.getInductionVars();
+ for (auto [iv, riv] : llvm::zip(ivs, llvm::reverse(newIvs))) {
mapping.map(iv, riv);
}
// Copy parallel loop body
``````````
</details>
https://github.com/llvm/llvm-project/pull/196076
More information about the Mlir-commits
mailing list