| //===- Passes.h - Pass Entrypoints ------------------------------*- C++ -*-===// |
| // |
| // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
| // See https://llvm.org/LICENSE.txt for license information. |
| // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #ifndef MLIR_DIALECT_ARMSME_TRANSFORMS_PASSES_H |
| #define MLIR_DIALECT_ARMSME_TRANSFORMS_PASSES_H |
| |
| #include "mlir/Conversion/LLVMCommon/TypeConverter.h" |
| #include "mlir/Dialect/ArmSME/Transforms/PassesEnums.h.inc" |
| #include "mlir/Pass/Pass.h" |
| |
| namespace mlir { |
| |
| class RewritePatternSet; |
| |
| namespace arm_sme { |
| //===----------------------------------------------------------------------===// |
| // The EnableArmStreaming pass. |
| //===----------------------------------------------------------------------===// |
| #define GEN_PASS_DECL |
| #include "mlir/Dialect/ArmSME/Transforms/Passes.h.inc" |
| |
| /// Pass to enable Armv9 Streaming SVE mode. |
| std::unique_ptr<Pass> createEnableArmStreamingPass( |
| const ArmStreamingMode = ArmStreamingMode::Streaming, |
| const ArmZaMode = ArmZaMode::Disabled, bool onlyIfRequiredByOps = false); |
| |
| /// Pass that allocates tile IDs to ArmSME operations. |
| std::unique_ptr<Pass> createTileAllocationPass(); |
| |
| /// Pass that fuses 'arm_sme.outerproduct' ops into 2-way or 4-way widening |
| /// variants. |
| std::unique_ptr<Pass> createOuterProductFusionPass(); |
| |
| /// Pass that legalizes vectors so they can be lowered to ArmSME. |
| std::unique_ptr<Pass> createVectorLegalizationPass(); |
| |
| //===----------------------------------------------------------------------===// |
| // Registration |
| //===----------------------------------------------------------------------===// |
| |
| /// Generate the code for registering passes. |
| #define GEN_PASS_REGISTRATION |
| #include "mlir/Dialect/ArmSME/Transforms/Passes.h.inc" |
| |
| } // namespace arm_sme |
| } // namespace mlir |
| |
| #endif // MLIR_DIALECT_ARMSME_TRANSFORMS_PASSES_H |