MLIR  20.0.0git
TopologicalSort.cpp
Go to the documentation of this file.
1 //===- TopologicalSort.cpp - Topological sort pass ------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 
10 
13 
14 namespace mlir {
15 #define GEN_PASS_DEF_TOPOLOGICALSORT
16 #include "mlir/Transforms/Passes.h.inc"
17 } // namespace mlir
18 
19 using namespace mlir;
20 
21 namespace {
22 struct TopologicalSortPass
23  : public impl::TopologicalSortBase<TopologicalSortPass> {
24  void runOnOperation() override {
25  // Topologically sort the regions of the operation without SSA dominance.
26  getOperation()->walk([](RegionKindInterface op) {
27  for (auto it : llvm::enumerate(op->getRegions())) {
28  if (op.hasSSADominance(it.index()))
29  continue;
30  for (Block &block : it.value())
31  sortTopologically(&block);
32  }
33  });
34  }
35 };
36 } // end anonymous namespace
37 
38 std::unique_ptr<Pass> mlir::createTopologicalSortPass() {
39  return std::make_unique<TopologicalSortPass>();
40 }
MutableArrayRef< Region > getRegions()
Returns the regions held by this operation.
Definition: Operation.h:672
constexpr void enumerate(std::tuple< Tys... > &tuple, CallbackT &&callback)
Definition: Matchers.h:344
Include the generated interface declarations.
std::unique_ptr< Pass > createTopologicalSortPass()
Creates a pass that recursively sorts nested regions without SSA dominance topologically such that,...