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
9#include "mlir/Transforms/Passes.h"
10
11#include "mlir/IR/RegionKindInterface.h"
12#include "mlir/Transforms/TopologicalSortUtils.h"
13
14namespace mlir {
15#define GEN_PASS_DEF_TOPOLOGICALSORT
16#include "mlir/Transforms/Passes.h.inc"
17} // namespace mlir
18
19using namespace mlir;
20
21namespace {
22struct 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
38std::unique_ptr<Pass> mlir::createTopologicalSortPass() {
39 return std::make_unique<TopologicalSortPass>();
40}
41

source code of mlir/lib/Transforms/TopologicalSort.cpp