| //===- Passes.h - Pass Entrypoints ------------------------------*- C++ -*-===// |
| // |
| // Copyright 2019 The MLIR Authors. |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| // ============================================================================= |
| // |
| // This header file defines prototypes that expose pass constructors in the loop |
| // transformation library. |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #ifndef MLIR_TRANSFORMS_PASSES_H |
| #define MLIR_TRANSFORMS_PASSES_H |
| |
| #include "mlir/Support/LLVM.h" |
| |
| namespace mlir { |
| |
| class FunctionPass; |
| class ModulePass; |
| |
| /// Creates a constant folding pass. |
| FunctionPass *createConstantFoldPass(); |
| |
| /// Creates an instance of the Canonicalizer pass. |
| FunctionPass *createCanonicalizerPass(); |
| |
| /// Creates a pass to vectorize loops, operations and data types using a |
| /// target-independent, n-D super-vector abstraction. |
| FunctionPass *createVectorizePass(); |
| |
| /// Creates a pass to allow independent testing of vectorizer functionality with |
| /// FileCheck. |
| FunctionPass *createVectorizerTestPass(); |
| |
| /// Creates a loop unrolling pass. Default option or command-line options take |
| /// effect if -1 is passed as parameter. |
| FunctionPass *createLoopUnrollPass(int unrollFactor = -1, int unrollFull = -1); |
| |
| /// Creates a loop unroll jam pass to unroll jam by the specified factor. A |
| /// factor of -1 lets the pass use the default factor or the one on the command |
| /// line if provided. |
| FunctionPass *createLoopUnrollAndJamPass(int unrollJamFactor = -1); |
| |
| /// Creates an simplification pass for affine structures. |
| FunctionPass *createSimplifyAffineStructuresPass(); |
| |
| /// Creates a loop fusion pass which fuses loops in MLFunctions. |
| FunctionPass *createLoopFusionPass(); |
| |
| /// Creates a pass to pipeline explicit movement of data across levels of the |
| /// memory hierarchy. |
| FunctionPass *createPipelineDataTransferPass(); |
| |
| /// Creates a pass which composes all affine maps applied to loads and stores. |
| FunctionPass *createComposeAffineMapsPass(); |
| |
| /// Replaces all ML functions in the module with equivalent CFG functions. |
| /// Function references are appropriately patched to refer to the newly |
| /// generated CFG functions. |
| ModulePass *createConvertToCFGPass(); |
| |
| /// Creates a pass to perform tiling on loop nests. |
| FunctionPass *createLoopTilingPass(); |
| |
| /// Promotes all accessed memref regions to the specified faster memory space |
| /// while generating DMAs to move data. |
| FunctionPass *createDmaGenerationPass(unsigned lowMemorySpace, |
| unsigned highMemorySpace, |
| int minDmaTransferSize = 1024); |
| |
| /// Replaces affine_apply operations in CFGFunctions with the arithmetic |
| /// primitives (addition, multplication) they comprise. Errors out on |
| /// MLFunctions since they may contain affine_applies baked into the For loop |
| /// bounds that cannot be replaced. |
| FunctionPass *createDeaffinatorPass(); |
| |
| } // end namespace mlir |
| |
| #endif // MLIR_TRANSFORMS_PASSES_H |