IR: de-duplicate two CmpInst routines (NFC) (#116866)
[llvm-project.git] / mlir / lib / Transforms / TopologicalSort.cpp
blob528f6ef6760209a7eb8cd42fa00e8806d0d0faaf
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 //===----------------------------------------------------------------------===//
9 #include "mlir/Transforms/Passes.h"
11 #include "mlir/Analysis/TopologicalSortUtils.h"
12 #include "mlir/IR/RegionKindInterface.h"
14 namespace mlir {
15 #define GEN_PASS_DEF_TOPOLOGICALSORT
16 #include "mlir/Transforms/Passes.h.inc"
17 } // namespace mlir
19 using namespace mlir;
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);
33 });
36 } // end anonymous namespace
38 std::unique_ptr<Pass> mlir::createTopologicalSortPass() {
39 return std::make_unique<TopologicalSortPass>();