MLIR 22.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
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}
Include the generated interface declarations.
std::unique_ptr< Pass > createTopologicalSortPass()
Creates a pass that recursively sorts nested regions without SSA dominance topologically such that,...
bool sortTopologically(Block *block, iterator_range< Block::iterator > ops, function_ref< bool(Value, Operation *)> isOperandReady=nullptr)
Given a block, sort a range operations in said block in topological order.