annotate mlir/lib/Transforms/LoopCoalescing.cpp @ 201:a96fbbdf2d0f

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Fri, 04 Jun 2021 21:07:06 +0900
parents 0572611fdcc8
children 2e18cbf3894f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 //===- LoopCoalescing.cpp - Pass transforming loop nests into single loops-===//
anatofuz
parents:
diff changeset
2 //
anatofuz
parents:
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
anatofuz
parents:
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
anatofuz
parents:
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
anatofuz
parents:
diff changeset
6 //
anatofuz
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
anatofuz
parents:
diff changeset
8
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
9 #include "PassDetail.h"
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
10 #include "mlir/Dialect/SCF/SCF.h"
150
anatofuz
parents:
diff changeset
11 #include "mlir/Transforms/LoopUtils.h"
anatofuz
parents:
diff changeset
12 #include "mlir/Transforms/Passes.h"
anatofuz
parents:
diff changeset
13 #include "mlir/Transforms/RegionUtils.h"
anatofuz
parents:
diff changeset
14 #include "llvm/Support/Debug.h"
anatofuz
parents:
diff changeset
15
anatofuz
parents:
diff changeset
16 #define PASS_NAME "loop-coalescing"
anatofuz
parents:
diff changeset
17 #define DEBUG_TYPE PASS_NAME
anatofuz
parents:
diff changeset
18
anatofuz
parents:
diff changeset
19 using namespace mlir;
anatofuz
parents:
diff changeset
20
anatofuz
parents:
diff changeset
21 namespace {
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
22 struct LoopCoalescingPass : public LoopCoalescingBase<LoopCoalescingPass> {
150
anatofuz
parents:
diff changeset
23 void runOnFunction() override {
anatofuz
parents:
diff changeset
24 FuncOp func = getFunction();
anatofuz
parents:
diff changeset
25
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
26 func.walk([](scf::ForOp op) {
150
anatofuz
parents:
diff changeset
27 // Ignore nested loops.
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
28 if (op.getParentOfType<scf::ForOp>())
150
anatofuz
parents:
diff changeset
29 return;
anatofuz
parents:
diff changeset
30
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
31 SmallVector<scf::ForOp, 4> loops;
150
anatofuz
parents:
diff changeset
32 getPerfectlyNestedLoops(loops, op);
anatofuz
parents:
diff changeset
33 LLVM_DEBUG(llvm::dbgs()
anatofuz
parents:
diff changeset
34 << "found a perfect nest of depth " << loops.size() << '\n');
anatofuz
parents:
diff changeset
35
anatofuz
parents:
diff changeset
36 // Look for a band of loops that can be coalesced, i.e. perfectly nested
anatofuz
parents:
diff changeset
37 // loops with bounds defined above some loop.
anatofuz
parents:
diff changeset
38 // 1. For each loop, find above which parent loop its operands are
anatofuz
parents:
diff changeset
39 // defined.
anatofuz
parents:
diff changeset
40 SmallVector<unsigned, 4> operandsDefinedAbove(loops.size());
anatofuz
parents:
diff changeset
41 for (unsigned i = 0, e = loops.size(); i < e; ++i) {
anatofuz
parents:
diff changeset
42 operandsDefinedAbove[i] = i;
anatofuz
parents:
diff changeset
43 for (unsigned j = 0; j < i; ++j) {
anatofuz
parents:
diff changeset
44 if (areValuesDefinedAbove(loops[i].getOperands(),
anatofuz
parents:
diff changeset
45 loops[j].region())) {
anatofuz
parents:
diff changeset
46 operandsDefinedAbove[i] = j;
anatofuz
parents:
diff changeset
47 break;
anatofuz
parents:
diff changeset
48 }
anatofuz
parents:
diff changeset
49 }
anatofuz
parents:
diff changeset
50 LLVM_DEBUG(llvm::dbgs()
anatofuz
parents:
diff changeset
51 << " bounds of loop " << i << " are known above depth "
anatofuz
parents:
diff changeset
52 << operandsDefinedAbove[i] << '\n');
anatofuz
parents:
diff changeset
53 }
anatofuz
parents:
diff changeset
54
anatofuz
parents:
diff changeset
55 // 2. Identify bands of loops such that the operands of all of them are
anatofuz
parents:
diff changeset
56 // defined above the first loop in the band. Traverse the nest bottom-up
anatofuz
parents:
diff changeset
57 // so that modifications don't invalidate the inner loops.
anatofuz
parents:
diff changeset
58 for (unsigned end = loops.size(); end > 0; --end) {
anatofuz
parents:
diff changeset
59 unsigned start = 0;
anatofuz
parents:
diff changeset
60 for (; start < end - 1; ++start) {
anatofuz
parents:
diff changeset
61 auto maxPos =
anatofuz
parents:
diff changeset
62 *std::max_element(std::next(operandsDefinedAbove.begin(), start),
anatofuz
parents:
diff changeset
63 std::next(operandsDefinedAbove.begin(), end));
anatofuz
parents:
diff changeset
64 if (maxPos > start)
anatofuz
parents:
diff changeset
65 continue;
anatofuz
parents:
diff changeset
66
anatofuz
parents:
diff changeset
67 assert(maxPos == start &&
anatofuz
parents:
diff changeset
68 "expected loop bounds to be known at the start of the band");
anatofuz
parents:
diff changeset
69 LLVM_DEBUG(llvm::dbgs() << " found coalesceable band from " << start
anatofuz
parents:
diff changeset
70 << " to " << end << '\n');
anatofuz
parents:
diff changeset
71
anatofuz
parents:
diff changeset
72 auto band =
anatofuz
parents:
diff changeset
73 llvm::makeMutableArrayRef(loops.data() + start, end - start);
anatofuz
parents:
diff changeset
74 coalesceLoops(band);
anatofuz
parents:
diff changeset
75 break;
anatofuz
parents:
diff changeset
76 }
anatofuz
parents:
diff changeset
77 // If a band was found and transformed, keep looking at the loops above
anatofuz
parents:
diff changeset
78 // the outermost transformed loop.
anatofuz
parents:
diff changeset
79 if (start != end - 1)
anatofuz
parents:
diff changeset
80 end = start + 1;
anatofuz
parents:
diff changeset
81 }
anatofuz
parents:
diff changeset
82 });
anatofuz
parents:
diff changeset
83 }
anatofuz
parents:
diff changeset
84 };
anatofuz
parents:
diff changeset
85
anatofuz
parents:
diff changeset
86 } // namespace
anatofuz
parents:
diff changeset
87
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
88 std::unique_ptr<OperationPass<FuncOp>> mlir::createLoopCoalescingPass() {
150
anatofuz
parents:
diff changeset
89 return std::make_unique<LoopCoalescingPass>();
anatofuz
parents:
diff changeset
90 }