[llvm] aa37a69 - [LoopInterchange] Move some processes to another function (NFC) (#129514)
via llvm-commits
llvm-commits at lists.llvm.org
Tue Mar 4 00:24:07 PST 2025
Author: Ryotaro Kasuga
Date: 2025-03-04T17:24:04+09:00
New Revision: aa37a698d4066058d03016ea467230bd039c1eb1
URL: https://github.com/llvm/llvm-project/commit/aa37a698d4066058d03016ea467230bd039c1eb1
DIFF: https://github.com/llvm/llvm-project/commit/aa37a698d4066058d03016ea467230bd039c1eb1.diff
LOG: [LoopInterchange] Move some processes to another function (NFC) (#129514)
Some post-processing involved in exchanging a pair of loops has been
done separately from `processLoop`, which is a main function that does
the transformation. It's better to consolidate these processes into the
same function. This patch is a preparation of #127474.
Added:
Modified:
llvm/lib/Transforms/Scalar/LoopInterchange.cpp
Removed:
################################################################################
diff --git a/llvm/lib/Transforms/Scalar/LoopInterchange.cpp b/llvm/lib/Transforms/Scalar/LoopInterchange.cpp
index f45d90ff13e14..967be109a7ba6 100644
--- a/llvm/lib/Transforms/Scalar/LoopInterchange.cpp
+++ b/llvm/lib/Transforms/Scalar/LoopInterchange.cpp
@@ -511,18 +511,8 @@ struct LoopInterchange {
for (unsigned j = SelecLoopId; j > 0; j--) {
bool ChangedPerIter = false;
for (unsigned i = SelecLoopId; i > SelecLoopId - j; i--) {
- bool Interchanged = processLoop(LoopList[i], LoopList[i - 1], i, i - 1,
- DependencyMatrix, CostMap);
- if (!Interchanged)
- continue;
- // Loops interchanged, update LoopList accordingly.
- std::swap(LoopList[i - 1], LoopList[i]);
- // Update the DependencyMatrix
- interChangeDependencies(DependencyMatrix, i, i - 1);
-
- LLVM_DEBUG(dbgs() << "Dependency matrix after interchange:\n";
- printDepMatrix(DependencyMatrix));
-
+ bool Interchanged =
+ processLoop(LoopList, i, i - 1, DependencyMatrix, CostMap);
ChangedPerIter |= Interchanged;
Changed |= Interchanged;
}
@@ -534,10 +524,12 @@ struct LoopInterchange {
return Changed;
}
- bool processLoop(Loop *InnerLoop, Loop *OuterLoop, unsigned InnerLoopId,
+ bool processLoop(SmallVectorImpl<Loop *> &LoopList, unsigned InnerLoopId,
unsigned OuterLoopId,
std::vector<std::vector<char>> &DependencyMatrix,
const DenseMap<const Loop *, unsigned> &CostMap) {
+ Loop *OuterLoop = LoopList[OuterLoopId];
+ Loop *InnerLoop = LoopList[InnerLoopId];
LLVM_DEBUG(dbgs() << "Processing InnerLoopId = " << InnerLoopId
<< " and OuterLoopId = " << OuterLoopId << "\n");
LoopInterchangeLegality LIL(OuterLoop, InnerLoop, SE, ORE);
@@ -566,6 +558,15 @@ struct LoopInterchange {
LoopsInterchanged++;
llvm::formLCSSARecursively(*OuterLoop, *DT, LI, SE);
+
+ // Loops interchanged, update LoopList accordingly.
+ std::swap(LoopList[OuterLoopId], LoopList[InnerLoopId]);
+ // Update the DependencyMatrix
+ interChangeDependencies(DependencyMatrix, InnerLoopId, OuterLoopId);
+
+ LLVM_DEBUG(dbgs() << "Dependency matrix after interchange:\n";
+ printDepMatrix(DependencyMatrix));
+
return true;
}
};
More information about the llvm-commits
mailing list