MLIR  22.0.0git
TosaLayerwiseConstantFoldPass.cpp
Go to the documentation of this file.
1 //===- TosaLayerwiseConstantFoldPass.cpp ----------------------------------===//
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 // This file implements constant folding transformations on TOSA operations
10 //
11 //===----------------------------------------------------------------------===//
12 
14 
17 
18 namespace mlir {
19 namespace tosa {
20 #define GEN_PASS_DEF_TOSALAYERWISECONSTANTFOLDPASS
21 #include "mlir/Dialect/Tosa/Transforms/Passes.h.inc"
22 } // namespace tosa
23 } // namespace mlir
24 
25 using namespace mlir;
26 using namespace mlir::tosa;
27 
28 namespace {
29 
30 template <typename... Args>
31 void addOpsCanonicalizations(MLIRContext *ctx, RewritePatternSet &patterns) {
32  (Args::getCanonicalizationPatterns(patterns, ctx), ...);
33 }
34 
35 void populateTosaOpsCanonicalizationPatterns(MLIRContext *ctx,
37  addOpsCanonicalizations<
38 #define GET_OP_LIST
39 #include "mlir/Dialect/Tosa/IR/TosaOps.cpp.inc"
40  >(ctx, patterns);
41 }
42 
43 struct TosaLayerwiseConstantFoldPass
44  : public tosa::impl::TosaLayerwiseConstantFoldPassBase<
45  TosaLayerwiseConstantFoldPass> {
46  using Base::Base;
47 
48  void runOnOperation() override {
49  auto *ctx = &getContext();
51  auto func = getOperation();
52 
56  aggressiveReduceConstant);
57  populateTosaOpsCanonicalizationPatterns(ctx, patterns);
58 
59  if (applyPatternsGreedily(func, std::move(patterns)).failed())
60  signalPassFailure();
61  }
62 };
63 
64 } // namespace
static MLIRContext * getContext(OpFoldResult val)
MLIRContext is the top-level object for a collection of MLIR operations.
Definition: MLIRContext.h:63
detail::InFlightRemark failed(Location loc, RemarkOpts opts)
Report an optimization remark that failed.
Definition: Remarks.h:491
void populateTosaConstantReduction(MLIRContext *ctx, RewritePatternSet &patterns, bool aggressiveReduceConstant)
void populateTosaFoldConstantReciprocalPatterns(MLIRContext *ctx, RewritePatternSet &patterns)
void populateTosaFoldConstantTransposePatterns(MLIRContext *ctx, RewritePatternSet &patterns)
Include the generated interface declarations.
LogicalResult applyPatternsGreedily(Region &region, const FrozenRewritePatternSet &patterns, GreedyRewriteConfig config=GreedyRewriteConfig(), bool *changed=nullptr)
Rewrite ops in the given region, which must be isolated from above, by repeatedly applying the highes...
const FrozenRewritePatternSet & patterns