1 //===- TopologicalSort.cpp - Topological sort pass ------------------------===//
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
7 //===----------------------------------------------------------------------===//
9 #include "mlir/Transforms/Passes.h"
11 #include "mlir/Analysis/TopologicalSortUtils.h"
12 #include "mlir/IR/RegionKindInterface.h"
15 #define GEN_PASS_DEF_TOPOLOGICALSORT
16 #include "mlir/Transforms/Passes.h.inc"
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()))
30 for (Block
&block
: it
.value())
31 sortTopologically(&block
);
36 } // end anonymous namespace
38 std::unique_ptr
<Pass
> mlir::createTopologicalSortPass() {
39 return std::make_unique
<TopologicalSortPass
>();