#ifdef GEN_PASS_DECL
#define GEN_PASS_DECL_CHECKUSESPASS
#define GEN_PASS_DECL_INFEREFFECTSPASS
#define GEN_PASS_DECL_INTERPRETERPASS
#define GEN_PASS_DECL_PRELOADLIBRARYPASS
#undef GEN_PASS_DECL
#endif
#ifdef GEN_PASS_DECL_CHECKUSESPASS
std::unique_ptr<::mlir::Pass> createCheckUsesPass();
#undef GEN_PASS_DECL_CHECKUSESPASS
#endif
#ifdef GEN_PASS_DEF_CHECKUSESPASS
namespace impl {
std::unique_ptr<::mlir::Pass> createCheckUsesPass();
}
namespace impl {
template <typename DerivedT>
class CheckUsesPassBase : public ::mlir::OperationPass<> {
public:
using Base = CheckUsesPassBase;
CheckUsesPassBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
CheckUsesPassBase(const CheckUsesPassBase &other) : ::mlir::OperationPass<>(other) {}
CheckUsesPassBase& operator=(const CheckUsesPassBase &) = delete;
CheckUsesPassBase(CheckUsesPassBase &&) = delete;
CheckUsesPassBase& operator=(CheckUsesPassBase &&) = delete;
~CheckUsesPassBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("transform-dialect-check-uses");
}
::llvm::StringRef getArgument() const override { return "transform-dialect-check-uses"; }
::llvm::StringRef getDescription() const override { return "warn about potential use-after-free in the transform dialect"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("CheckUsesPass");
}
::llvm::StringRef getName() const override { return "CheckUsesPass"; }
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 {
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(CheckUsesPassBase<DerivedT>)
protected:
private:
friend std::unique_ptr<::mlir::Pass> createCheckUsesPass() {
return std::make_unique<DerivedT>();
}
};
}
std::unique_ptr<::mlir::Pass> createCheckUsesPass() {
return impl::createCheckUsesPass();
}
#undef GEN_PASS_DEF_CHECKUSESPASS
#endif
#ifdef GEN_PASS_DECL_INFEREFFECTSPASS
std::unique_ptr<::mlir::Pass> createInferEffectsPass();
#undef GEN_PASS_DECL_INFEREFFECTSPASS
#endif
#ifdef GEN_PASS_DEF_INFEREFFECTSPASS
namespace impl {
std::unique_ptr<::mlir::Pass> createInferEffectsPass();
}
namespace impl {
template <typename DerivedT>
class InferEffectsPassBase : public ::mlir::OperationPass<> {
public:
using Base = InferEffectsPassBase;
InferEffectsPassBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
InferEffectsPassBase(const InferEffectsPassBase &other) : ::mlir::OperationPass<>(other) {}
InferEffectsPassBase& operator=(const InferEffectsPassBase &) = delete;
InferEffectsPassBase(InferEffectsPassBase &&) = delete;
InferEffectsPassBase& operator=(InferEffectsPassBase &&) = delete;
~InferEffectsPassBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("transform-infer-effects");
}
::llvm::StringRef getArgument() const override { return "transform-infer-effects"; }
::llvm::StringRef getDescription() const override { return "infer transform side effects for symbols"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("InferEffectsPass");
}
::llvm::StringRef getName() const override { return "InferEffectsPass"; }
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 {
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(InferEffectsPassBase<DerivedT>)
protected:
private:
friend std::unique_ptr<::mlir::Pass> createInferEffectsPass() {
return std::make_unique<DerivedT>();
}
};
}
std::unique_ptr<::mlir::Pass> createInferEffectsPass() {
return impl::createInferEffectsPass();
}
#undef GEN_PASS_DEF_INFEREFFECTSPASS
#endif
#ifdef GEN_PASS_DECL_INTERPRETERPASS
struct InterpreterPassOptions { … };
std::unique_ptr<::mlir::Pass> createInterpreterPass();
std::unique_ptr<::mlir::Pass> createInterpreterPass(const InterpreterPassOptions &options);
#undef GEN_PASS_DECL_INTERPRETERPASS
#endif
#ifdef GEN_PASS_DEF_INTERPRETERPASS
namespace impl {
std::unique_ptr<::mlir::Pass> createInterpreterPass();
}
namespace impl {
std::unique_ptr<::mlir::Pass> createInterpreterPass(const InterpreterPassOptions &options);
}
namespace impl {
template <typename DerivedT>
class InterpreterPassBase : public ::mlir::OperationPass<> {
public:
using Base = InterpreterPassBase;
InterpreterPassBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
InterpreterPassBase(const InterpreterPassBase &other) : ::mlir::OperationPass<>(other) {}
InterpreterPassBase& operator=(const InterpreterPassBase &) = delete;
InterpreterPassBase(InterpreterPassBase &&) = delete;
InterpreterPassBase& operator=(InterpreterPassBase &&) = delete;
~InterpreterPassBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("transform-interpreter");
}
::llvm::StringRef getArgument() const override { return "transform-interpreter"; }
::llvm::StringRef getDescription() const override { return "transform dialect interpreter"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("InterpreterPass");
}
::llvm::StringRef getName() const override { return "InterpreterPass"; }
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<::mlir::transform::TransformDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(InterpreterPassBase<DerivedT>)
InterpreterPassBase(const InterpreterPassOptions &options) : InterpreterPassBase() {
debugPayloadRootTag = options.debugPayloadRootTag;
debugBindTrailingArgs = options.debugBindTrailingArgs;
disableExpensiveChecks = options.disableExpensiveChecks;
entryPoint = options.entryPoint;
}
protected:
::mlir::Pass::Option<std::string> debugPayloadRootTag{*this, "debug-payload-root-tag", ::llvm::cl::desc("Select the operation with 'transform.target_tag' attribute having the given value as payload IR root. If empty select the pass anchor operation as the payload IR root."), ::llvm::cl::init("")};
::mlir::Pass::ListOption<std::string> debugBindTrailingArgs{*this, "debug-bind-trailing-args", ::llvm::cl::desc("Binds trailing arguments of the entry point to the payload operations with specified names.")};
::mlir::Pass::Option<bool> disableExpensiveChecks{*this, "disable-expensive-checks", ::llvm::cl::desc("Disable expensive checks in the interpreter for a faster run."), ::llvm::cl::init(false)};
::mlir::Pass::Option<std::string> entryPoint{*this, "entry-point", ::llvm::cl::desc("Entry point of the pass pipeline."), ::llvm::cl::init(
TransformDialect::kTransformEntryPointSymbolName.str()
)};
private:
friend std::unique_ptr<::mlir::Pass> createInterpreterPass() {
return std::make_unique<DerivedT>();
}
friend std::unique_ptr<::mlir::Pass> createInterpreterPass(const InterpreterPassOptions &options) {
return std::make_unique<DerivedT>(options);
}
};
}
std::unique_ptr<::mlir::Pass> createInterpreterPass() {
return impl::createInterpreterPass();
}
std::unique_ptr<::mlir::Pass> createInterpreterPass(const InterpreterPassOptions &options) {
return impl::createInterpreterPass(options);
}
#undef GEN_PASS_DEF_INTERPRETERPASS
#endif
#ifdef GEN_PASS_DECL_PRELOADLIBRARYPASS
struct PreloadLibraryPassOptions { … };
std::unique_ptr<::mlir::Pass> createPreloadLibraryPass();
std::unique_ptr<::mlir::Pass> createPreloadLibraryPass(const PreloadLibraryPassOptions &options);
#undef GEN_PASS_DECL_PRELOADLIBRARYPASS
#endif
#ifdef GEN_PASS_DEF_PRELOADLIBRARYPASS
namespace impl {
std::unique_ptr<::mlir::Pass> createPreloadLibraryPass();
}
namespace impl {
std::unique_ptr<::mlir::Pass> createPreloadLibraryPass(const PreloadLibraryPassOptions &options);
}
namespace impl {
template <typename DerivedT>
class PreloadLibraryPassBase : public ::mlir::OperationPass<> {
public:
using Base = PreloadLibraryPassBase;
PreloadLibraryPassBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
PreloadLibraryPassBase(const PreloadLibraryPassBase &other) : ::mlir::OperationPass<>(other) {}
PreloadLibraryPassBase& operator=(const PreloadLibraryPassBase &) = delete;
PreloadLibraryPassBase(PreloadLibraryPassBase &&) = delete;
PreloadLibraryPassBase& operator=(PreloadLibraryPassBase &&) = delete;
~PreloadLibraryPassBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("transform-preload-library");
}
::llvm::StringRef getArgument() const override { return "transform-preload-library"; }
::llvm::StringRef getDescription() const override { return "preload transform dialect library"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("PreloadLibraryPass");
}
::llvm::StringRef getName() const override { return "PreloadLibraryPass"; }
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<::mlir::transform::TransformDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(PreloadLibraryPassBase<DerivedT>)
PreloadLibraryPassBase(const PreloadLibraryPassOptions &options) : PreloadLibraryPassBase() {
transformLibraryPaths = options.transformLibraryPaths;
}
protected:
::mlir::Pass::ListOption<std::string> transformLibraryPaths{*this, "transform-library-paths", ::llvm::cl::desc("Optional paths to files with modules that should be merged into the transform module to provide the definitions of external named sequences.")};
private:
friend std::unique_ptr<::mlir::Pass> createPreloadLibraryPass() {
return std::make_unique<DerivedT>();
}
friend std::unique_ptr<::mlir::Pass> createPreloadLibraryPass(const PreloadLibraryPassOptions &options) {
return std::make_unique<DerivedT>(options);
}
};
}
std::unique_ptr<::mlir::Pass> createPreloadLibraryPass() {
return impl::createPreloadLibraryPass();
}
std::unique_ptr<::mlir::Pass> createPreloadLibraryPass(const PreloadLibraryPassOptions &options) {
return impl::createPreloadLibraryPass(options);
}
#undef GEN_PASS_DEF_PRELOADLIBRARYPASS
#endif
#ifdef GEN_PASS_REGISTRATION
inline void registerCheckUsesPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return createCheckUsesPass();
});
}
inline void registerCheckUsesPassPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return createCheckUsesPass();
});
}
inline void registerInferEffectsPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return createInferEffectsPass();
});
}
inline void registerInferEffectsPassPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return createInferEffectsPass();
});
}
inline void registerInterpreterPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return createInterpreterPass();
});
}
inline void registerInterpreterPassPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return createInterpreterPass();
});
}
inline void registerPreloadLibraryPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return createPreloadLibraryPass();
});
}
inline void registerPreloadLibraryPassPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return createPreloadLibraryPass();
});
}
inline void registerTransformPasses() {
registerCheckUsesPass();
registerInferEffectsPass();
registerInterpreterPass();
registerPreloadLibraryPass();
}
#undef GEN_PASS_REGISTRATION
#endif
#ifdef GEN_PASS_CLASSES
template <typename DerivedT>
class CheckUsesPassBase : public ::mlir::OperationPass<> {
public:
using Base = CheckUsesPassBase;
CheckUsesPassBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
CheckUsesPassBase(const CheckUsesPassBase &other) : ::mlir::OperationPass<>(other) {}
CheckUsesPassBase& operator=(const CheckUsesPassBase &) = delete;
CheckUsesPassBase(CheckUsesPassBase &&) = delete;
CheckUsesPassBase& operator=(CheckUsesPassBase &&) = delete;
~CheckUsesPassBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("transform-dialect-check-uses");
}
::llvm::StringRef getArgument() const override { return "transform-dialect-check-uses"; }
::llvm::StringRef getDescription() const override { return "warn about potential use-after-free in the transform dialect"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("CheckUsesPass");
}
::llvm::StringRef getName() const override { return "CheckUsesPass"; }
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 {
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(CheckUsesPassBase<DerivedT>)
protected:
};
template <typename DerivedT>
class InferEffectsPassBase : public ::mlir::OperationPass<> {
public:
using Base = InferEffectsPassBase;
InferEffectsPassBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
InferEffectsPassBase(const InferEffectsPassBase &other) : ::mlir::OperationPass<>(other) {}
InferEffectsPassBase& operator=(const InferEffectsPassBase &) = delete;
InferEffectsPassBase(InferEffectsPassBase &&) = delete;
InferEffectsPassBase& operator=(InferEffectsPassBase &&) = delete;
~InferEffectsPassBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("transform-infer-effects");
}
::llvm::StringRef getArgument() const override { return "transform-infer-effects"; }
::llvm::StringRef getDescription() const override { return "infer transform side effects for symbols"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("InferEffectsPass");
}
::llvm::StringRef getName() const override { return "InferEffectsPass"; }
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 {
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(InferEffectsPassBase<DerivedT>)
protected:
};
template <typename DerivedT>
class InterpreterPassBase : public ::mlir::OperationPass<> {
public:
using Base = InterpreterPassBase;
InterpreterPassBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
InterpreterPassBase(const InterpreterPassBase &other) : ::mlir::OperationPass<>(other) {}
InterpreterPassBase& operator=(const InterpreterPassBase &) = delete;
InterpreterPassBase(InterpreterPassBase &&) = delete;
InterpreterPassBase& operator=(InterpreterPassBase &&) = delete;
~InterpreterPassBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("transform-interpreter");
}
::llvm::StringRef getArgument() const override { return "transform-interpreter"; }
::llvm::StringRef getDescription() const override { return "transform dialect interpreter"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("InterpreterPass");
}
::llvm::StringRef getName() const override { return "InterpreterPass"; }
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<::mlir::transform::TransformDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(InterpreterPassBase<DerivedT>)
protected:
::mlir::Pass::Option<std::string> debugPayloadRootTag{*this, "debug-payload-root-tag", ::llvm::cl::desc("Select the operation with 'transform.target_tag' attribute having the given value as payload IR root. If empty select the pass anchor operation as the payload IR root."), ::llvm::cl::init("")};
::mlir::Pass::ListOption<std::string> debugBindTrailingArgs{*this, "debug-bind-trailing-args", ::llvm::cl::desc("Binds trailing arguments of the entry point to the payload operations with specified names.")};
::mlir::Pass::Option<bool> disableExpensiveChecks{*this, "disable-expensive-checks", ::llvm::cl::desc("Disable expensive checks in the interpreter for a faster run."), ::llvm::cl::init(false)};
::mlir::Pass::Option<std::string> entryPoint{*this, "entry-point", ::llvm::cl::desc("Entry point of the pass pipeline."), ::llvm::cl::init(
TransformDialect::kTransformEntryPointSymbolName.str()
)};
};
template <typename DerivedT>
class PreloadLibraryPassBase : public ::mlir::OperationPass<> {
public:
using Base = PreloadLibraryPassBase;
PreloadLibraryPassBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
PreloadLibraryPassBase(const PreloadLibraryPassBase &other) : ::mlir::OperationPass<>(other) {}
PreloadLibraryPassBase& operator=(const PreloadLibraryPassBase &) = delete;
PreloadLibraryPassBase(PreloadLibraryPassBase &&) = delete;
PreloadLibraryPassBase& operator=(PreloadLibraryPassBase &&) = delete;
~PreloadLibraryPassBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("transform-preload-library");
}
::llvm::StringRef getArgument() const override { return "transform-preload-library"; }
::llvm::StringRef getDescription() const override { return "preload transform dialect library"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("PreloadLibraryPass");
}
::llvm::StringRef getName() const override { return "PreloadLibraryPass"; }
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<::mlir::transform::TransformDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(PreloadLibraryPassBase<DerivedT>)
protected:
::mlir::Pass::ListOption<std::string> transformLibraryPaths{*this, "transform-library-paths", ::llvm::cl::desc("Optional paths to files with modules that should be merged into the transform module to provide the definitions of external named sequences.")};
};
#undef GEN_PASS_CLASSES
#endif