#ifdef GEN_PASS_DECL
#define GEN_PASS_DECL_ENABLEARMSTREAMING
#define GEN_PASS_DECL_OUTERPRODUCTFUSION
#define GEN_PASS_DECL_TESTTILEALLOCATION
#define GEN_PASS_DECL_VECTORLEGALIZATION
#undef GEN_PASS_DECL
#endif
#ifdef GEN_PASS_DECL_ENABLEARMSTREAMING
struct EnableArmStreamingOptions { … };
#undef GEN_PASS_DECL_ENABLEARMSTREAMING
#endif
#ifdef GEN_PASS_DEF_ENABLEARMSTREAMING
namespace impl {
template <typename DerivedT>
class EnableArmStreamingBase : public ::mlir::OperationPass<mlir::func::FuncOp> {
public:
using Base = EnableArmStreamingBase;
EnableArmStreamingBase() : ::mlir::OperationPass<mlir::func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
EnableArmStreamingBase(const EnableArmStreamingBase &other) : ::mlir::OperationPass<mlir::func::FuncOp>(other) {}
EnableArmStreamingBase& operator=(const EnableArmStreamingBase &) = delete;
EnableArmStreamingBase(EnableArmStreamingBase &&) = delete;
EnableArmStreamingBase& operator=(EnableArmStreamingBase &&) = delete;
~EnableArmStreamingBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("enable-arm-streaming");
}
::llvm::StringRef getArgument() const override { return "enable-arm-streaming"; }
::llvm::StringRef getDescription() const override { return "Enable Armv9 Streaming SVE mode"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("EnableArmStreaming");
}
::llvm::StringRef getName() const override { return "EnableArmStreaming"; }
static bool classof(const ::mlir::Pass *pass) {
return pass->getTypeID() == ::mlir::TypeID::get<DerivedT>();
}
std::unique_ptr<::mlir::Pass> clonePass() const override {
return std::make_unique<DerivedT>(*static_cast<const DerivedT *>(this));
}
void getDependentDialects(::mlir::DialectRegistry ®istry) const override {
registry.insert<func::FuncDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(EnableArmStreamingBase<DerivedT>)
EnableArmStreamingBase(const EnableArmStreamingOptions &options) : EnableArmStreamingBase() {
streamingMode = options.streamingMode;
zaMode = options.zaMode;
ifRequiredByOps = options.ifRequiredByOps;
ifScalableAndSupported = options.ifScalableAndSupported;
}
protected:
::mlir::Pass::Option<mlir::arm_sme::ArmStreamingMode> streamingMode{*this, "streaming-mode", ::llvm::cl::desc("Select how streaming-mode is managed at the function-level."), ::llvm::cl::init(mlir::arm_sme::ArmStreamingMode::Streaming), ::llvm::cl::values(
clEnumValN(mlir::arm_sme::ArmStreamingMode::Disabled,
"disabled", "Streaming mode is disabled."),
clEnumValN(mlir::arm_sme::ArmStreamingMode::Streaming,
"streaming",
"Streaming mode is part of the function interface "
"(ABI), caller manages PSTATE.SM on entry/exit."),
clEnumValN(mlir::arm_sme::ArmStreamingMode::StreamingLocally,
"streaming-locally",
"Streaming mode is internal to the function, callee "
"manages PSTATE.SM on entry/exit."),
clEnumValN(mlir::arm_sme::ArmStreamingMode::StreamingCompatible,
"streaming-compatible",
"Function supports both streaming and non-streaming "
"modes.")
)};
::mlir::Pass::Option<mlir::arm_sme::ArmZaMode> zaMode{*this, "za-mode", ::llvm::cl::desc("Select how ZA-storage is managed at the function-level."), ::llvm::cl::init(mlir::arm_sme::ArmZaMode::Disabled), ::llvm::cl::values(
clEnumValN(mlir::arm_sme::ArmZaMode::Disabled,
"disabled", "ZA storage is disabled."),
clEnumValN(mlir::arm_sme::ArmZaMode::NewZA,
"new-za",
"The function has ZA state. The ZA state is "
"created on entry and destroyed on exit."),
clEnumValN(mlir::arm_sme::ArmZaMode::InZA,
"in-za",
"The function uses ZA state. The ZA state may "
"be used for input."),
clEnumValN(mlir::arm_sme::ArmZaMode::OutZA,
"out-za",
"The function uses ZA state. The ZA state may "
"be used for output."),
clEnumValN(mlir::arm_sme::ArmZaMode::InOutZA,
"inout-za",
"The function uses ZA state. The ZA state may "
"be used for input and/or output."),
clEnumValN(mlir::arm_sme::ArmZaMode::PreservesZA,
"preserves-za",
"The function shares ZA state. The ZA state may "
"not be used for input and/or output and the "
"function must return with ZA unchanged")
)};
::mlir::Pass::Option<bool> ifRequiredByOps{*this, "if-required-by-ops", ::llvm::cl::desc("Only apply the selected streaming/ZA modes if the function contains ops that implement the ArmSMETileOpInterface."), ::llvm::cl::init(false)};
::mlir::Pass::Option<bool> ifScalableAndSupported{*this, "if-scalable-and-supported", ::llvm::cl::desc("Only apply the selected streaming/ZA modes if the function contains supported scalable vector operations."), ::llvm::cl::init(false)};
private:
};
}
#undef GEN_PASS_DEF_ENABLEARMSTREAMING
#endif
#ifdef GEN_PASS_DECL_OUTERPRODUCTFUSION
#undef GEN_PASS_DECL_OUTERPRODUCTFUSION
#endif
#ifdef GEN_PASS_DEF_OUTERPRODUCTFUSION
namespace impl {
template <typename DerivedT>
class OuterProductFusionBase : public ::mlir::OperationPass<mlir::func::FuncOp> {
public:
using Base = OuterProductFusionBase;
OuterProductFusionBase() : ::mlir::OperationPass<mlir::func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
OuterProductFusionBase(const OuterProductFusionBase &other) : ::mlir::OperationPass<mlir::func::FuncOp>(other) {}
OuterProductFusionBase& operator=(const OuterProductFusionBase &) = delete;
OuterProductFusionBase(OuterProductFusionBase &&) = delete;
OuterProductFusionBase& operator=(OuterProductFusionBase &&) = delete;
~OuterProductFusionBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("arm-sme-outer-product-fusion");
}
::llvm::StringRef getArgument() const override { return "arm-sme-outer-product-fusion"; }
::llvm::StringRef getDescription() const override { return "Fuse 'arm_sme.outerproduct' operations into 2-way or 4-way widening variants"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("OuterProductFusion");
}
::llvm::StringRef getName() const override { return "OuterProductFusion"; }
static bool classof(const ::mlir::Pass *pass) {
return pass->getTypeID() == ::mlir::TypeID::get<DerivedT>();
}
std::unique_ptr<::mlir::Pass> clonePass() const override {
return std::make_unique<DerivedT>(*static_cast<const DerivedT *>(this));
}
void getDependentDialects(::mlir::DialectRegistry ®istry) const override {
registry.insert<func::FuncDialect>();
registry.insert<arm_sme::ArmSMEDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(OuterProductFusionBase<DerivedT>)
protected:
private:
};
}
#undef GEN_PASS_DEF_OUTERPRODUCTFUSION
#endif
#ifdef GEN_PASS_DECL_TESTTILEALLOCATION
struct TestTileAllocationOptions { … };
std::unique_ptr<::mlir::Pass> createTestTileAllocation();
std::unique_ptr<::mlir::Pass> createTestTileAllocation(const TestTileAllocationOptions &options);
#undef GEN_PASS_DECL_TESTTILEALLOCATION
#endif
#ifdef GEN_PASS_DEF_TESTTILEALLOCATION
namespace impl {
std::unique_ptr<::mlir::Pass> createTestTileAllocation();
}
namespace impl {
std::unique_ptr<::mlir::Pass> createTestTileAllocation(const TestTileAllocationOptions &options);
}
namespace impl {
template <typename DerivedT>
class TestTileAllocationBase : public ::mlir::OperationPass<mlir::func::FuncOp> {
public:
using Base = TestTileAllocationBase;
TestTileAllocationBase() : ::mlir::OperationPass<mlir::func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
TestTileAllocationBase(const TestTileAllocationBase &other) : ::mlir::OperationPass<mlir::func::FuncOp>(other) {}
TestTileAllocationBase& operator=(const TestTileAllocationBase &) = delete;
TestTileAllocationBase(TestTileAllocationBase &&) = delete;
TestTileAllocationBase& operator=(TestTileAllocationBase &&) = delete;
~TestTileAllocationBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("test-arm-sme-tile-allocation");
}
::llvm::StringRef getArgument() const override { return "test-arm-sme-tile-allocation"; }
::llvm::StringRef getDescription() const override { return "Tests SME 'virtual tile' allocation"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("TestTileAllocation");
}
::llvm::StringRef getName() const override { return "TestTileAllocation"; }
static bool classof(const ::mlir::Pass *pass) {
return pass->getTypeID() == ::mlir::TypeID::get<DerivedT>();
}
std::unique_ptr<::mlir::Pass> clonePass() const override {
return std::make_unique<DerivedT>(*static_cast<const DerivedT *>(this));
}
void getDependentDialects(::mlir::DialectRegistry ®istry) const override {
registry.insert<func::FuncDialect>();
registry.insert<arm_sme::ArmSMEDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(TestTileAllocationBase<DerivedT>)
TestTileAllocationBase(const TestTileAllocationOptions &options) : TestTileAllocationBase() {
dumpTileLiveRanges = options.dumpTileLiveRanges;
preprocessOnly = options.preprocessOnly;
}
protected:
::mlir::Pass::Option<bool> dumpTileLiveRanges{*this, "dump-tile-live-ranges", ::llvm::cl::desc("Dump the live ranges of SME tiles (for debugging)"), ::llvm::cl::init(false)};
::mlir::Pass::Option<bool> preprocessOnly{*this, "preprocess-only", ::llvm::cl::desc("Only preprocess IR so it is ready for tile allocation (but do not allocate any tiles)"), ::llvm::cl::init(false)};
private:
friend std::unique_ptr<::mlir::Pass> createTestTileAllocation() {
return std::make_unique<DerivedT>();
}
friend std::unique_ptr<::mlir::Pass> createTestTileAllocation(const TestTileAllocationOptions &options) {
return std::make_unique<DerivedT>(options);
}
};
}
std::unique_ptr<::mlir::Pass> createTestTileAllocation() {
return impl::createTestTileAllocation();
}
std::unique_ptr<::mlir::Pass> createTestTileAllocation(const TestTileAllocationOptions &options) {
return impl::createTestTileAllocation(options);
}
#undef GEN_PASS_DEF_TESTTILEALLOCATION
#endif
#ifdef GEN_PASS_DECL_VECTORLEGALIZATION
#undef GEN_PASS_DECL_VECTORLEGALIZATION
#endif
#ifdef GEN_PASS_DEF_VECTORLEGALIZATION
namespace impl {
template <typename DerivedT>
class VectorLegalizationBase : public ::mlir::OperationPass<mlir::ModuleOp> {
public:
using Base = VectorLegalizationBase;
VectorLegalizationBase() : ::mlir::OperationPass<mlir::ModuleOp>(::mlir::TypeID::get<DerivedT>()) {}
VectorLegalizationBase(const VectorLegalizationBase &other) : ::mlir::OperationPass<mlir::ModuleOp>(other) {}
VectorLegalizationBase& operator=(const VectorLegalizationBase &) = delete;
VectorLegalizationBase(VectorLegalizationBase &&) = delete;
VectorLegalizationBase& operator=(VectorLegalizationBase &&) = delete;
~VectorLegalizationBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("arm-sme-vector-legalization");
}
::llvm::StringRef getArgument() const override { return "arm-sme-vector-legalization"; }
::llvm::StringRef getDescription() const override { return "Legalize vectors for ArmSME"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("VectorLegalization");
}
::llvm::StringRef getName() const override { return "VectorLegalization"; }
static bool classof(const ::mlir::Pass *pass) {
return pass->getTypeID() == ::mlir::TypeID::get<DerivedT>();
}
std::unique_ptr<::mlir::Pass> clonePass() const override {
return std::make_unique<DerivedT>(*static_cast<const DerivedT *>(this));
}
void getDependentDialects(::mlir::DialectRegistry ®istry) const override {
registry.insert<func::FuncDialect>();
registry.insert<arm_sme::ArmSMEDialect>();
registry.insert<vector::VectorDialect>();
registry.insert<arith::ArithDialect>();
registry.insert<index::IndexDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(VectorLegalizationBase<DerivedT>)
protected:
private:
};
}
#undef GEN_PASS_DEF_VECTORLEGALIZATION
#endif
#ifdef GEN_PASS_REGISTRATION
inline void registerEnableArmStreaming() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::arm_sme::createEnableArmStreamingPass();
});
}
inline void registerEnableArmStreamingPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::arm_sme::createEnableArmStreamingPass();
});
}
inline void registerOuterProductFusion() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::arm_sme::createOuterProductFusionPass();
});
}
inline void registerOuterProductFusionPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::arm_sme::createOuterProductFusionPass();
});
}
inline void registerTestTileAllocation() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return createTestTileAllocation();
});
}
inline void registerTestTileAllocationPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return createTestTileAllocation();
});
}
inline void registerVectorLegalization() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::arm_sme::createVectorLegalizationPass();
});
}
inline void registerVectorLegalizationPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::arm_sme::createVectorLegalizationPass();
});
}
inline void registerArmSMEPasses() {
registerEnableArmStreaming();
registerOuterProductFusion();
registerTestTileAllocation();
registerVectorLegalization();
}
#undef GEN_PASS_REGISTRATION
#endif
#ifdef GEN_PASS_CLASSES
template <typename DerivedT>
class EnableArmStreamingBase : public ::mlir::OperationPass<mlir::func::FuncOp> {
public:
using Base = EnableArmStreamingBase;
EnableArmStreamingBase() : ::mlir::OperationPass<mlir::func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
EnableArmStreamingBase(const EnableArmStreamingBase &other) : ::mlir::OperationPass<mlir::func::FuncOp>(other) {}
EnableArmStreamingBase& operator=(const EnableArmStreamingBase &) = delete;
EnableArmStreamingBase(EnableArmStreamingBase &&) = delete;
EnableArmStreamingBase& operator=(EnableArmStreamingBase &&) = delete;
~EnableArmStreamingBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("enable-arm-streaming");
}
::llvm::StringRef getArgument() const override { return "enable-arm-streaming"; }
::llvm::StringRef getDescription() const override { return "Enable Armv9 Streaming SVE mode"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("EnableArmStreaming");
}
::llvm::StringRef getName() const override { return "EnableArmStreaming"; }
static bool classof(const ::mlir::Pass *pass) {
return pass->getTypeID() == ::mlir::TypeID::get<DerivedT>();
}
std::unique_ptr<::mlir::Pass> clonePass() const override {
return std::make_unique<DerivedT>(*static_cast<const DerivedT *>(this));
}
void getDependentDialects(::mlir::DialectRegistry ®istry) const override {
registry.insert<func::FuncDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(EnableArmStreamingBase<DerivedT>)
protected:
::mlir::Pass::Option<mlir::arm_sme::ArmStreamingMode> streamingMode{*this, "streaming-mode", ::llvm::cl::desc("Select how streaming-mode is managed at the function-level."), ::llvm::cl::init(mlir::arm_sme::ArmStreamingMode::Streaming), ::llvm::cl::values(
clEnumValN(mlir::arm_sme::ArmStreamingMode::Disabled,
"disabled", "Streaming mode is disabled."),
clEnumValN(mlir::arm_sme::ArmStreamingMode::Streaming,
"streaming",
"Streaming mode is part of the function interface "
"(ABI), caller manages PSTATE.SM on entry/exit."),
clEnumValN(mlir::arm_sme::ArmStreamingMode::StreamingLocally,
"streaming-locally",
"Streaming mode is internal to the function, callee "
"manages PSTATE.SM on entry/exit."),
clEnumValN(mlir::arm_sme::ArmStreamingMode::StreamingCompatible,
"streaming-compatible",
"Function supports both streaming and non-streaming "
"modes.")
)};
::mlir::Pass::Option<mlir::arm_sme::ArmZaMode> zaMode{*this, "za-mode", ::llvm::cl::desc("Select how ZA-storage is managed at the function-level."), ::llvm::cl::init(mlir::arm_sme::ArmZaMode::Disabled), ::llvm::cl::values(
clEnumValN(mlir::arm_sme::ArmZaMode::Disabled,
"disabled", "ZA storage is disabled."),
clEnumValN(mlir::arm_sme::ArmZaMode::NewZA,
"new-za",
"The function has ZA state. The ZA state is "
"created on entry and destroyed on exit."),
clEnumValN(mlir::arm_sme::ArmZaMode::InZA,
"in-za",
"The function uses ZA state. The ZA state may "
"be used for input."),
clEnumValN(mlir::arm_sme::ArmZaMode::OutZA,
"out-za",
"The function uses ZA state. The ZA state may "
"be used for output."),
clEnumValN(mlir::arm_sme::ArmZaMode::InOutZA,
"inout-za",
"The function uses ZA state. The ZA state may "
"be used for input and/or output."),
clEnumValN(mlir::arm_sme::ArmZaMode::PreservesZA,
"preserves-za",
"The function shares ZA state. The ZA state may "
"not be used for input and/or output and the "
"function must return with ZA unchanged")
)};
::mlir::Pass::Option<bool> ifRequiredByOps{*this, "if-required-by-ops", ::llvm::cl::desc("Only apply the selected streaming/ZA modes if the function contains ops that implement the ArmSMETileOpInterface."), ::llvm::cl::init(false)};
::mlir::Pass::Option<bool> ifScalableAndSupported{*this, "if-scalable-and-supported", ::llvm::cl::desc("Only apply the selected streaming/ZA modes if the function contains supported scalable vector operations."), ::llvm::cl::init(false)};
};
template <typename DerivedT>
class OuterProductFusionBase : public ::mlir::OperationPass<mlir::func::FuncOp> {
public:
using Base = OuterProductFusionBase;
OuterProductFusionBase() : ::mlir::OperationPass<mlir::func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
OuterProductFusionBase(const OuterProductFusionBase &other) : ::mlir::OperationPass<mlir::func::FuncOp>(other) {}
OuterProductFusionBase& operator=(const OuterProductFusionBase &) = delete;
OuterProductFusionBase(OuterProductFusionBase &&) = delete;
OuterProductFusionBase& operator=(OuterProductFusionBase &&) = delete;
~OuterProductFusionBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("arm-sme-outer-product-fusion");
}
::llvm::StringRef getArgument() const override { return "arm-sme-outer-product-fusion"; }
::llvm::StringRef getDescription() const override { return "Fuse 'arm_sme.outerproduct' operations into 2-way or 4-way widening variants"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("OuterProductFusion");
}
::llvm::StringRef getName() const override { return "OuterProductFusion"; }
static bool classof(const ::mlir::Pass *pass) {
return pass->getTypeID() == ::mlir::TypeID::get<DerivedT>();
}
std::unique_ptr<::mlir::Pass> clonePass() const override {
return std::make_unique<DerivedT>(*static_cast<const DerivedT *>(this));
}
void getDependentDialects(::mlir::DialectRegistry ®istry) const override {
registry.insert<func::FuncDialect>();
registry.insert<arm_sme::ArmSMEDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(OuterProductFusionBase<DerivedT>)
protected:
};
template <typename DerivedT>
class TestTileAllocationBase : public ::mlir::OperationPass<mlir::func::FuncOp> {
public:
using Base = TestTileAllocationBase;
TestTileAllocationBase() : ::mlir::OperationPass<mlir::func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
TestTileAllocationBase(const TestTileAllocationBase &other) : ::mlir::OperationPass<mlir::func::FuncOp>(other) {}
TestTileAllocationBase& operator=(const TestTileAllocationBase &) = delete;
TestTileAllocationBase(TestTileAllocationBase &&) = delete;
TestTileAllocationBase& operator=(TestTileAllocationBase &&) = delete;
~TestTileAllocationBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("test-arm-sme-tile-allocation");
}
::llvm::StringRef getArgument() const override { return "test-arm-sme-tile-allocation"; }
::llvm::StringRef getDescription() const override { return "Tests SME 'virtual tile' allocation"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("TestTileAllocation");
}
::llvm::StringRef getName() const override { return "TestTileAllocation"; }
static bool classof(const ::mlir::Pass *pass) {
return pass->getTypeID() == ::mlir::TypeID::get<DerivedT>();
}
std::unique_ptr<::mlir::Pass> clonePass() const override {
return std::make_unique<DerivedT>(*static_cast<const DerivedT *>(this));
}
void getDependentDialects(::mlir::DialectRegistry ®istry) const override {
registry.insert<func::FuncDialect>();
registry.insert<arm_sme::ArmSMEDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(TestTileAllocationBase<DerivedT>)
protected:
::mlir::Pass::Option<bool> dumpTileLiveRanges{*this, "dump-tile-live-ranges", ::llvm::cl::desc("Dump the live ranges of SME tiles (for debugging)"), ::llvm::cl::init(false)};
::mlir::Pass::Option<bool> preprocessOnly{*this, "preprocess-only", ::llvm::cl::desc("Only preprocess IR so it is ready for tile allocation (but do not allocate any tiles)"), ::llvm::cl::init(false)};
};
template <typename DerivedT>
class VectorLegalizationBase : public ::mlir::OperationPass<mlir::ModuleOp> {
public:
using Base = VectorLegalizationBase;
VectorLegalizationBase() : ::mlir::OperationPass<mlir::ModuleOp>(::mlir::TypeID::get<DerivedT>()) {}
VectorLegalizationBase(const VectorLegalizationBase &other) : ::mlir::OperationPass<mlir::ModuleOp>(other) {}
VectorLegalizationBase& operator=(const VectorLegalizationBase &) = delete;
VectorLegalizationBase(VectorLegalizationBase &&) = delete;
VectorLegalizationBase& operator=(VectorLegalizationBase &&) = delete;
~VectorLegalizationBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("arm-sme-vector-legalization");
}
::llvm::StringRef getArgument() const override { return "arm-sme-vector-legalization"; }
::llvm::StringRef getDescription() const override { return "Legalize vectors for ArmSME"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("VectorLegalization");
}
::llvm::StringRef getName() const override { return "VectorLegalization"; }
static bool classof(const ::mlir::Pass *pass) {
return pass->getTypeID() == ::mlir::TypeID::get<DerivedT>();
}
std::unique_ptr<::mlir::Pass> clonePass() const override {
return std::make_unique<DerivedT>(*static_cast<const DerivedT *>(this));
}
void getDependentDialects(::mlir::DialectRegistry ®istry) const override {
registry.insert<func::FuncDialect>();
registry.insert<arm_sme::ArmSMEDialect>();
registry.insert<vector::VectorDialect>();
registry.insert<arith::ArithDialect>();
registry.insert<index::IndexDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(VectorLegalizationBase<DerivedT>)
protected:
};
#undef GEN_PASS_CLASSES
#endif