picceler
Loading...
Searching...
No Matches
pass_manager.h
Go to the documentation of this file.
1#pragma once
2
3#include <memory>
4
5#include "spdlog/spdlog.h"
6
7#include "mlir/Pass/PassManager.h"
8#include "llvm/Support/raw_ostream.h"
9#include "llvm/Support/FileSystem.h"
10#include "mlir/Pass/PassInstrumentation.h"
11
12#include "passes.h"
13
14namespace picceler {
15
16struct PassLogger : public mlir::PassInstrumentation {
17 void runBeforePass(mlir::Pass *pass, mlir::Operation *op) override {
18 spdlog::info("Started pass: {}", pass->getName().str());
19 }
20 void runAfterPass(mlir::Pass *pass, mlir::Operation *op) override {
21 spdlog::info("Finished pass: {}", pass->getName().str());
22 }
23 void runAfterPassFailed(mlir::Pass *pass, mlir::Operation *op) override {
24 spdlog::error("Failed pass: {}", pass->getName().str());
25 }
26};
27
32public:
38 IRPassManager(mlir::MLIRContext *context);
39
44 void run(mlir::ModuleOp module);
45
46private:
50 void addPasses();
51
56
57 void addHighLevelOptimizationPasses();
58 void addAffineLoweringPasses();
59 void addRuntimeLoweringPasses();
60 void addBackendLoweringPasses();
61
62private:
63 std::unique_ptr<llvm::raw_fd_ostream> _outStream;
64 mlir::PassManager _passManager;
65};
66
67} // namespace picceler
void run(mlir::ModuleOp module)
Runs the pass manager on the given MLIR module.
Definition pass_manager.cpp:30
IRPassManager(mlir::MLIRContext *context)
Constructs an IRPassManager with the given MLIR context. Also sets up the output stream and configure...
Definition pass_manager.cpp:14
Definition ast.h:11
Definition pass_manager.h:16
void runAfterPass(mlir::Pass *pass, mlir::Operation *op) override
Definition pass_manager.h:20
void runBeforePass(mlir::Pass *pass, mlir::Operation *op) override
Definition pass_manager.h:17
void runAfterPassFailed(mlir::Pass *pass, mlir::Operation *op) override
Definition pass_manager.h:23