#ifdef GEN_PASS_DECL
#define GEN_PASS_DECL_BUFFERDEALLOCATION
#define GEN_PASS_DECL_BUFFERDEALLOCATIONSIMPLIFICATION
#define GEN_PASS_DECL_BUFFERHOISTING
#define GEN_PASS_DECL_BUFFERLOOPHOISTING
#define GEN_PASS_DECL_BUFFERRESULTSTOOUTPARAMS
#define GEN_PASS_DECL_DROPEQUIVALENTBUFFERRESULTS
#define GEN_PASS_DECL_EMPTYTENSORELIMINATION
#define GEN_PASS_DECL_EMPTYTENSORTOALLOCTENSOR
#define GEN_PASS_DECL_FINALIZINGBUFFERIZE
#define GEN_PASS_DECL_LOWERDEALLOCATIONS
#define GEN_PASS_DECL_ONESHOTBUFFERIZE
#define GEN_PASS_DECL_OPTIMIZEALLOCATIONLIVENESS
#define GEN_PASS_DECL_OWNERSHIPBASEDBUFFERDEALLOCATION
#define GEN_PASS_DECL_PROMOTEBUFFERSTOSTACK
#undef GEN_PASS_DECL
#endif
#ifdef GEN_PASS_DECL_BUFFERDEALLOCATION
#undef GEN_PASS_DECL_BUFFERDEALLOCATION
#endif
#ifdef GEN_PASS_DEF_BUFFERDEALLOCATION
namespace impl {
template <typename DerivedT>
class BufferDeallocationBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = BufferDeallocationBase;
BufferDeallocationBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
BufferDeallocationBase(const BufferDeallocationBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
BufferDeallocationBase& operator=(const BufferDeallocationBase &) = delete;
BufferDeallocationBase(BufferDeallocationBase &&) = delete;
BufferDeallocationBase& operator=(BufferDeallocationBase &&) = delete;
~BufferDeallocationBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("buffer-deallocation");
}
::llvm::StringRef getArgument() const override { return "buffer-deallocation"; }
::llvm::StringRef getDescription() const override { return "Adds all required dealloc operations for all allocations in the input program"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("BufferDeallocation");
}
::llvm::StringRef getName() const override { return "BufferDeallocation"; }
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(BufferDeallocationBase<DerivedT>)
protected:
private:
};
}
#undef GEN_PASS_DEF_BUFFERDEALLOCATION
#endif
#ifdef GEN_PASS_DECL_BUFFERDEALLOCATIONSIMPLIFICATION
#undef GEN_PASS_DECL_BUFFERDEALLOCATIONSIMPLIFICATION
#endif
#ifdef GEN_PASS_DEF_BUFFERDEALLOCATIONSIMPLIFICATION
namespace impl {
template <typename DerivedT>
class BufferDeallocationSimplificationBase : public ::mlir::OperationPass<> {
public:
using Base = BufferDeallocationSimplificationBase;
BufferDeallocationSimplificationBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
BufferDeallocationSimplificationBase(const BufferDeallocationSimplificationBase &other) : ::mlir::OperationPass<>(other) {}
BufferDeallocationSimplificationBase& operator=(const BufferDeallocationSimplificationBase &) = delete;
BufferDeallocationSimplificationBase(BufferDeallocationSimplificationBase &&) = delete;
BufferDeallocationSimplificationBase& operator=(BufferDeallocationSimplificationBase &&) = delete;
~BufferDeallocationSimplificationBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("buffer-deallocation-simplification");
}
::llvm::StringRef getArgument() const override { return "buffer-deallocation-simplification"; }
::llvm::StringRef getDescription() const override { return "Optimizes `bufferization.dealloc` operation for more efficient codegen"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("BufferDeallocationSimplification");
}
::llvm::StringRef getName() const override { return "BufferDeallocationSimplification"; }
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::bufferization::BufferizationDialect>();
registry.insert<mlir::arith::ArithDialect>();
registry.insert<mlir::memref::MemRefDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(BufferDeallocationSimplificationBase<DerivedT>)
protected:
private:
};
}
#undef GEN_PASS_DEF_BUFFERDEALLOCATIONSIMPLIFICATION
#endif
#ifdef GEN_PASS_DECL_BUFFERHOISTING
#undef GEN_PASS_DECL_BUFFERHOISTING
#endif
#ifdef GEN_PASS_DEF_BUFFERHOISTING
namespace impl {
template <typename DerivedT>
class BufferHoistingBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = BufferHoistingBase;
BufferHoistingBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
BufferHoistingBase(const BufferHoistingBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
BufferHoistingBase& operator=(const BufferHoistingBase &) = delete;
BufferHoistingBase(BufferHoistingBase &&) = delete;
BufferHoistingBase& operator=(BufferHoistingBase &&) = delete;
~BufferHoistingBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("buffer-hoisting");
}
::llvm::StringRef getArgument() const override { return "buffer-hoisting"; }
::llvm::StringRef getDescription() const override { return "Optimizes placement of allocation operations by moving them into common dominators and out of nested regions"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("BufferHoisting");
}
::llvm::StringRef getName() const override { return "BufferHoisting"; }
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(BufferHoistingBase<DerivedT>)
protected:
private:
};
}
#undef GEN_PASS_DEF_BUFFERHOISTING
#endif
#ifdef GEN_PASS_DECL_BUFFERLOOPHOISTING
#undef GEN_PASS_DECL_BUFFERLOOPHOISTING
#endif
#ifdef GEN_PASS_DEF_BUFFERLOOPHOISTING
namespace impl {
template <typename DerivedT>
class BufferLoopHoistingBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = BufferLoopHoistingBase;
BufferLoopHoistingBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
BufferLoopHoistingBase(const BufferLoopHoistingBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
BufferLoopHoistingBase& operator=(const BufferLoopHoistingBase &) = delete;
BufferLoopHoistingBase(BufferLoopHoistingBase &&) = delete;
BufferLoopHoistingBase& operator=(BufferLoopHoistingBase &&) = delete;
~BufferLoopHoistingBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("buffer-loop-hoisting");
}
::llvm::StringRef getArgument() const override { return "buffer-loop-hoisting"; }
::llvm::StringRef getDescription() const override { return "Optimizes placement of allocation operations by moving them out of loop nests"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("BufferLoopHoisting");
}
::llvm::StringRef getName() const override { return "BufferLoopHoisting"; }
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(BufferLoopHoistingBase<DerivedT>)
protected:
private:
};
}
#undef GEN_PASS_DEF_BUFFERLOOPHOISTING
#endif
#ifdef GEN_PASS_DECL_BUFFERRESULTSTOOUTPARAMS
struct BufferResultsToOutParamsOptions { … };
#undef GEN_PASS_DECL_BUFFERRESULTSTOOUTPARAMS
#endif
#ifdef GEN_PASS_DEF_BUFFERRESULTSTOOUTPARAMS
namespace impl {
template <typename DerivedT>
class BufferResultsToOutParamsBase : public ::mlir::OperationPass<ModuleOp> {
public:
using Base = BufferResultsToOutParamsBase;
BufferResultsToOutParamsBase() : ::mlir::OperationPass<ModuleOp>(::mlir::TypeID::get<DerivedT>()) {}
BufferResultsToOutParamsBase(const BufferResultsToOutParamsBase &other) : ::mlir::OperationPass<ModuleOp>(other) {}
BufferResultsToOutParamsBase& operator=(const BufferResultsToOutParamsBase &) = delete;
BufferResultsToOutParamsBase(BufferResultsToOutParamsBase &&) = delete;
BufferResultsToOutParamsBase& operator=(BufferResultsToOutParamsBase &&) = delete;
~BufferResultsToOutParamsBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("buffer-results-to-out-params");
}
::llvm::StringRef getArgument() const override { return "buffer-results-to-out-params"; }
::llvm::StringRef getDescription() const override { return "Converts memref-typed function results to out-params"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("BufferResultsToOutParams");
}
::llvm::StringRef getName() const override { return "BufferResultsToOutParams"; }
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<memref::MemRefDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(BufferResultsToOutParamsBase<DerivedT>)
BufferResultsToOutParamsBase(const BufferResultsToOutParamsOptions &options) : BufferResultsToOutParamsBase() {
addResultAttribute = options.addResultAttribute;
hoistStaticAllocs = options.hoistStaticAllocs;
}
protected:
::mlir::Pass::Option<bool> addResultAttribute{*this, "add-result-attr", ::llvm::cl::desc("Add the attribute 'bufferize.result' to all output parameters."), ::llvm::cl::init(false)};
::mlir::Pass::Option<bool> hoistStaticAllocs{*this, "hoist-static-allocs", ::llvm::cl::desc("Hoist static allocations to call sites."), ::llvm::cl::init(false)};
private:
};
}
#undef GEN_PASS_DEF_BUFFERRESULTSTOOUTPARAMS
#endif
#ifdef GEN_PASS_DECL_DROPEQUIVALENTBUFFERRESULTS
#undef GEN_PASS_DECL_DROPEQUIVALENTBUFFERRESULTS
#endif
#ifdef GEN_PASS_DEF_DROPEQUIVALENTBUFFERRESULTS
namespace impl {
template <typename DerivedT>
class DropEquivalentBufferResultsBase : public ::mlir::OperationPass<ModuleOp> {
public:
using Base = DropEquivalentBufferResultsBase;
DropEquivalentBufferResultsBase() : ::mlir::OperationPass<ModuleOp>(::mlir::TypeID::get<DerivedT>()) {}
DropEquivalentBufferResultsBase(const DropEquivalentBufferResultsBase &other) : ::mlir::OperationPass<ModuleOp>(other) {}
DropEquivalentBufferResultsBase& operator=(const DropEquivalentBufferResultsBase &) = delete;
DropEquivalentBufferResultsBase(DropEquivalentBufferResultsBase &&) = delete;
DropEquivalentBufferResultsBase& operator=(DropEquivalentBufferResultsBase &&) = delete;
~DropEquivalentBufferResultsBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("drop-equivalent-buffer-results");
}
::llvm::StringRef getArgument() const override { return "drop-equivalent-buffer-results"; }
::llvm::StringRef getDescription() const override { return "Remove MemRef return values that are equivalent to a bbArg"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("DropEquivalentBufferResults");
}
::llvm::StringRef getName() const override { return "DropEquivalentBufferResults"; }
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<memref::MemRefDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(DropEquivalentBufferResultsBase<DerivedT>)
protected:
private:
};
}
#undef GEN_PASS_DEF_DROPEQUIVALENTBUFFERRESULTS
#endif
#ifdef GEN_PASS_DECL_EMPTYTENSORELIMINATION
#undef GEN_PASS_DECL_EMPTYTENSORELIMINATION
#endif
#ifdef GEN_PASS_DEF_EMPTYTENSORELIMINATION
namespace impl {
template <typename DerivedT>
class EmptyTensorEliminationBase : public ::mlir::OperationPass<> {
public:
using Base = EmptyTensorEliminationBase;
EmptyTensorEliminationBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
EmptyTensorEliminationBase(const EmptyTensorEliminationBase &other) : ::mlir::OperationPass<>(other) {}
EmptyTensorEliminationBase& operator=(const EmptyTensorEliminationBase &) = delete;
EmptyTensorEliminationBase(EmptyTensorEliminationBase &&) = delete;
EmptyTensorEliminationBase& operator=(EmptyTensorEliminationBase &&) = delete;
~EmptyTensorEliminationBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("eliminate-empty-tensors");
}
::llvm::StringRef getArgument() const override { return "eliminate-empty-tensors"; }
::llvm::StringRef getDescription() const override { return "Try to eliminate all tensor.empty ops."; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("EmptyTensorElimination");
}
::llvm::StringRef getName() const override { return "EmptyTensorElimination"; }
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(EmptyTensorEliminationBase<DerivedT>)
protected:
private:
};
}
#undef GEN_PASS_DEF_EMPTYTENSORELIMINATION
#endif
#ifdef GEN_PASS_DECL_EMPTYTENSORTOALLOCTENSOR
#undef GEN_PASS_DECL_EMPTYTENSORTOALLOCTENSOR
#endif
#ifdef GEN_PASS_DEF_EMPTYTENSORTOALLOCTENSOR
namespace impl {
template <typename DerivedT>
class EmptyTensorToAllocTensorBase : public ::mlir::OperationPass<> {
public:
using Base = EmptyTensorToAllocTensorBase;
EmptyTensorToAllocTensorBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
EmptyTensorToAllocTensorBase(const EmptyTensorToAllocTensorBase &other) : ::mlir::OperationPass<>(other) {}
EmptyTensorToAllocTensorBase& operator=(const EmptyTensorToAllocTensorBase &) = delete;
EmptyTensorToAllocTensorBase(EmptyTensorToAllocTensorBase &&) = delete;
EmptyTensorToAllocTensorBase& operator=(EmptyTensorToAllocTensorBase &&) = delete;
~EmptyTensorToAllocTensorBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("empty-tensor-to-alloc-tensor");
}
::llvm::StringRef getArgument() const override { return "empty-tensor-to-alloc-tensor"; }
::llvm::StringRef getDescription() const override { return "Replace all empty ops by alloc_tensor ops."; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("EmptyTensorToAllocTensor");
}
::llvm::StringRef getName() const override { return "EmptyTensorToAllocTensor"; }
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<tensor::TensorDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(EmptyTensorToAllocTensorBase<DerivedT>)
protected:
private:
};
}
#undef GEN_PASS_DEF_EMPTYTENSORTOALLOCTENSOR
#endif
#ifdef GEN_PASS_DECL_FINALIZINGBUFFERIZE
#undef GEN_PASS_DECL_FINALIZINGBUFFERIZE
#endif
#ifdef GEN_PASS_DEF_FINALIZINGBUFFERIZE
namespace impl {
template <typename DerivedT>
class FinalizingBufferizeBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = FinalizingBufferizeBase;
FinalizingBufferizeBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
FinalizingBufferizeBase(const FinalizingBufferizeBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
FinalizingBufferizeBase& operator=(const FinalizingBufferizeBase &) = delete;
FinalizingBufferizeBase(FinalizingBufferizeBase &&) = delete;
FinalizingBufferizeBase& operator=(FinalizingBufferizeBase &&) = delete;
~FinalizingBufferizeBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("finalizing-bufferize");
}
::llvm::StringRef getArgument() const override { return "finalizing-bufferize"; }
::llvm::StringRef getDescription() const override { return "Finalize a partial bufferization"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("FinalizingBufferize");
}
::llvm::StringRef getName() const override { return "FinalizingBufferize"; }
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(FinalizingBufferizeBase<DerivedT>)
protected:
private:
};
}
#undef GEN_PASS_DEF_FINALIZINGBUFFERIZE
#endif
#ifdef GEN_PASS_DECL_LOWERDEALLOCATIONS
#undef GEN_PASS_DECL_LOWERDEALLOCATIONS
#endif
#ifdef GEN_PASS_DEF_LOWERDEALLOCATIONS
namespace impl {
template <typename DerivedT>
class LowerDeallocationsBase : public ::mlir::OperationPass<> {
public:
using Base = LowerDeallocationsBase;
LowerDeallocationsBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
LowerDeallocationsBase(const LowerDeallocationsBase &other) : ::mlir::OperationPass<>(other) {}
LowerDeallocationsBase& operator=(const LowerDeallocationsBase &) = delete;
LowerDeallocationsBase(LowerDeallocationsBase &&) = delete;
LowerDeallocationsBase& operator=(LowerDeallocationsBase &&) = delete;
~LowerDeallocationsBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("bufferization-lower-deallocations");
}
::llvm::StringRef getArgument() const override { return "bufferization-lower-deallocations"; }
::llvm::StringRef getDescription() const override { return "Lowers `bufferization.dealloc` operations to `memref.dealloc`operations"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("LowerDeallocations");
}
::llvm::StringRef getName() const override { return "LowerDeallocations"; }
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<arith::ArithDialect>();
registry.insert<memref::MemRefDialect>();
registry.insert<scf::SCFDialect>();
registry.insert<func::FuncDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(LowerDeallocationsBase<DerivedT>)
protected:
private:
};
}
#undef GEN_PASS_DEF_LOWERDEALLOCATIONS
#endif
#ifdef GEN_PASS_DECL_ONESHOTBUFFERIZE
struct OneShotBufferizeOptions { … };
#undef GEN_PASS_DECL_ONESHOTBUFFERIZE
#endif
#ifdef GEN_PASS_DEF_ONESHOTBUFFERIZE
namespace impl {
template <typename DerivedT>
class OneShotBufferizeBase : public ::mlir::OperationPass<ModuleOp> {
public:
using Base = OneShotBufferizeBase;
OneShotBufferizeBase() : ::mlir::OperationPass<ModuleOp>(::mlir::TypeID::get<DerivedT>()) {}
OneShotBufferizeBase(const OneShotBufferizeBase &other) : ::mlir::OperationPass<ModuleOp>(other) {}
OneShotBufferizeBase& operator=(const OneShotBufferizeBase &) = delete;
OneShotBufferizeBase(OneShotBufferizeBase &&) = delete;
OneShotBufferizeBase& operator=(OneShotBufferizeBase &&) = delete;
~OneShotBufferizeBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("one-shot-bufferize");
}
::llvm::StringRef getArgument() const override { return "one-shot-bufferize"; }
::llvm::StringRef getDescription() const override { return "One-Shot Bufferize"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("OneShotBufferize");
}
::llvm::StringRef getName() const override { return "OneShotBufferize"; }
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(OneShotBufferizeBase<DerivedT>)
OneShotBufferizeBase(const OneShotBufferizeOptions &options) : OneShotBufferizeBase() {
allowReturnAllocsFromLoops = options.allowReturnAllocsFromLoops;
allowUnknownOps = options.allowUnknownOps;
analysisFuzzerSeed = options.analysisFuzzerSeed;
analysisHeuristic = options.analysisHeuristic;
bufferizeFunctionBoundaries = options.bufferizeFunctionBoundaries;
checkParallelRegions = options.checkParallelRegions;
copyBeforeWrite = options.copyBeforeWrite;
dialectFilter = options.dialectFilter;
dumpAliasSets = options.dumpAliasSets;
noAnalysisFuncFilter = options.noAnalysisFuncFilter;
functionBoundaryTypeConversion = options.functionBoundaryTypeConversion;
mustInferMemorySpace = options.mustInferMemorySpace;
testAnalysisOnly = options.testAnalysisOnly;
printConflicts = options.printConflicts;
unknownTypeConversion = options.unknownTypeConversion;
}
protected:
::mlir::Pass::Option<bool> allowReturnAllocsFromLoops{*this, "allow-return-allocs-from-loops", ::llvm::cl::desc("Allows returning/yielding new allocations from a loop."), ::llvm::cl::init(false)};
::mlir::Pass::Option<bool> allowUnknownOps{*this, "allow-unknown-ops", ::llvm::cl::desc("Allows unknown (not bufferizable) ops in the input IR."), ::llvm::cl::init(false)};
::mlir::Pass::Option<unsigned> analysisFuzzerSeed{*this, "analysis-fuzzer-seed", ::llvm::cl::desc("Test only: Analyze ops in random order with a given seed (fuzzer)"), ::llvm::cl::init(0)};
::mlir::Pass::Option<std::string> analysisHeuristic{*this, "analysis-heuristic", ::llvm::cl::desc("Heuristic that control the IR traversal during analysis"), ::llvm::cl::init("bottom-up")};
::mlir::Pass::Option<bool> bufferizeFunctionBoundaries{*this, "bufferize-function-boundaries", ::llvm::cl::desc("Bufferize function boundaries (experimental)."), ::llvm::cl::init(0)};
::mlir::Pass::Option<bool> checkParallelRegions{*this, "check-parallel-regions", ::llvm::cl::desc("Account for parallel regions in RaW analysis."), ::llvm::cl::init(true)};
::mlir::Pass::Option<bool> copyBeforeWrite{*this, "copy-before-write", ::llvm::cl::desc("Skip the analysis. Make a buffer copy on every write."), ::llvm::cl::init(false)};
::mlir::Pass::ListOption<std::string> dialectFilter{*this, "dialect-filter", ::llvm::cl::desc("Restrict bufferization to ops from these dialects.")};
::mlir::Pass::Option<bool> dumpAliasSets{*this, "dump-alias-sets", ::llvm::cl::desc("Test only: Annotate tensor IR with alias sets"), ::llvm::cl::init(false)};
::mlir::Pass::ListOption<std::string> noAnalysisFuncFilter{*this, "no-analysis-func-filter", ::llvm::cl::desc("Skip analysis of functions with these symbol names.Set copyBeforeWrite to true when bufferizing them.")};
::mlir::Pass::Option<std::string> functionBoundaryTypeConversion{*this, "function-boundary-type-conversion", ::llvm::cl::desc("Controls layout maps when bufferizing function signatures."), ::llvm::cl::init("infer-layout-map")};
::mlir::Pass::Option<bool> mustInferMemorySpace{*this, "must-infer-memory-space", ::llvm::cl::desc("The memory space of an memref types must always be inferred. If unset, a default memory space of 0 is used otherwise."), ::llvm::cl::init(false)};
::mlir::Pass::Option<bool> testAnalysisOnly{*this, "test-analysis-only", ::llvm::cl::desc("Test only: Only run inplaceability analysis and annotate IR"), ::llvm::cl::init(false)};
::mlir::Pass::Option<bool> printConflicts{*this, "print-conflicts", ::llvm::cl::desc("Test only: Annotate IR with RaW conflicts. Requires test-analysis-only."), ::llvm::cl::init(false)};
::mlir::Pass::Option<std::string> unknownTypeConversion{*this, "unknown-type-conversion", ::llvm::cl::desc("Controls layout maps for non-inferrable memref types."), ::llvm::cl::init("fully-dynamic-layout-map")};
::mlir::Pass::Statistic numBufferAlloc{this, "num-buffer-alloc", "Number of buffer allocations"};
::mlir::Pass::Statistic numTensorInPlace{this, "num-tensor-in-place", "Number of in-place tensor OpOperands"};
::mlir::Pass::Statistic numTensorOutOfPlace{this, "num-tensor-out-of-place", "Number of out-of-place tensor OpOperands"};
private:
};
}
#undef GEN_PASS_DEF_ONESHOTBUFFERIZE
#endif
#ifdef GEN_PASS_DECL_OPTIMIZEALLOCATIONLIVENESS
#undef GEN_PASS_DECL_OPTIMIZEALLOCATIONLIVENESS
#endif
#ifdef GEN_PASS_DEF_OPTIMIZEALLOCATIONLIVENESS
namespace impl {
template <typename DerivedT>
class OptimizeAllocationLivenessBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = OptimizeAllocationLivenessBase;
OptimizeAllocationLivenessBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
OptimizeAllocationLivenessBase(const OptimizeAllocationLivenessBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
OptimizeAllocationLivenessBase& operator=(const OptimizeAllocationLivenessBase &) = delete;
OptimizeAllocationLivenessBase(OptimizeAllocationLivenessBase &&) = delete;
OptimizeAllocationLivenessBase& operator=(OptimizeAllocationLivenessBase &&) = delete;
~OptimizeAllocationLivenessBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("optimize-allocation-liveness");
}
::llvm::StringRef getArgument() const override { return "optimize-allocation-liveness"; }
::llvm::StringRef getDescription() const override { return "This pass optimizes the liveness of temp allocations in the input function"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("OptimizeAllocationLiveness");
}
::llvm::StringRef getName() const override { return "OptimizeAllocationLiveness"; }
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::memref::MemRefDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(OptimizeAllocationLivenessBase<DerivedT>)
protected:
private:
};
}
#undef GEN_PASS_DEF_OPTIMIZEALLOCATIONLIVENESS
#endif
#ifdef GEN_PASS_DECL_OWNERSHIPBASEDBUFFERDEALLOCATION
struct OwnershipBasedBufferDeallocationOptions { … };
#undef GEN_PASS_DECL_OWNERSHIPBASEDBUFFERDEALLOCATION
#endif
#ifdef GEN_PASS_DEF_OWNERSHIPBASEDBUFFERDEALLOCATION
namespace impl {
template <typename DerivedT>
class OwnershipBasedBufferDeallocationBase : public ::mlir::OperationPass<> {
public:
using Base = OwnershipBasedBufferDeallocationBase;
OwnershipBasedBufferDeallocationBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
OwnershipBasedBufferDeallocationBase(const OwnershipBasedBufferDeallocationBase &other) : ::mlir::OperationPass<>(other) {}
OwnershipBasedBufferDeallocationBase& operator=(const OwnershipBasedBufferDeallocationBase &) = delete;
OwnershipBasedBufferDeallocationBase(OwnershipBasedBufferDeallocationBase &&) = delete;
OwnershipBasedBufferDeallocationBase& operator=(OwnershipBasedBufferDeallocationBase &&) = delete;
~OwnershipBasedBufferDeallocationBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("ownership-based-buffer-deallocation");
}
::llvm::StringRef getArgument() const override { return "ownership-based-buffer-deallocation"; }
::llvm::StringRef getDescription() const override { return "Adds all required dealloc operations for all allocations in the input program"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("OwnershipBasedBufferDeallocation");
}
::llvm::StringRef getName() const override { return "OwnershipBasedBufferDeallocation"; }
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::bufferization::BufferizationDialect>();
registry.insert<mlir::arith::ArithDialect>();
registry.insert<mlir::memref::MemRefDialect>();
registry.insert<mlir::scf::SCFDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(OwnershipBasedBufferDeallocationBase<DerivedT>)
OwnershipBasedBufferDeallocationBase(const OwnershipBasedBufferDeallocationOptions &options) : OwnershipBasedBufferDeallocationBase() {
privateFuncDynamicOwnership = options.privateFuncDynamicOwnership;
}
protected:
::mlir::Pass::Option<bool> privateFuncDynamicOwnership{*this, "private-function-dynamic-ownership", ::llvm::cl::desc("Allows to add additional arguments to private functions to dynamically pass ownership of memrefs to callees. This can enable earlier deallocations."), ::llvm::cl::init(false)};
private:
};
}
#undef GEN_PASS_DEF_OWNERSHIPBASEDBUFFERDEALLOCATION
#endif
#ifdef GEN_PASS_DECL_PROMOTEBUFFERSTOSTACK
struct PromoteBuffersToStackOptions { … };
#undef GEN_PASS_DECL_PROMOTEBUFFERSTOSTACK
#endif
#ifdef GEN_PASS_DEF_PROMOTEBUFFERSTOSTACK
namespace impl {
template <typename DerivedT>
class PromoteBuffersToStackBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = PromoteBuffersToStackBase;
PromoteBuffersToStackBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
PromoteBuffersToStackBase(const PromoteBuffersToStackBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
PromoteBuffersToStackBase& operator=(const PromoteBuffersToStackBase &) = delete;
PromoteBuffersToStackBase(PromoteBuffersToStackBase &&) = delete;
PromoteBuffersToStackBase& operator=(PromoteBuffersToStackBase &&) = delete;
~PromoteBuffersToStackBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("promote-buffers-to-stack");
}
::llvm::StringRef getArgument() const override { return "promote-buffers-to-stack"; }
::llvm::StringRef getDescription() const override { return "Promotes heap-based allocations to automatically managed stack-based allocations"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("PromoteBuffersToStack");
}
::llvm::StringRef getName() const override { return "PromoteBuffersToStack"; }
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(PromoteBuffersToStackBase<DerivedT>)
PromoteBuffersToStackBase(const PromoteBuffersToStackOptions &options) : PromoteBuffersToStackBase() {
maxAllocSizeInBytes = options.maxAllocSizeInBytes;
maxRankOfAllocatedMemRef = options.maxRankOfAllocatedMemRef;
}
protected:
::mlir::Pass::Option<unsigned> maxAllocSizeInBytes{*this, "max-alloc-size-in-bytes", ::llvm::cl::desc("Maximal size in bytes to promote allocations to stack."), ::llvm::cl::init(1024)};
::mlir::Pass::Option<unsigned> maxRankOfAllocatedMemRef{*this, "max-rank-of-allocated-memref", ::llvm::cl::desc("Maximal memref rank to promote dynamic buffers."), ::llvm::cl::init(1)};
private:
};
}
#undef GEN_PASS_DEF_PROMOTEBUFFERSTOSTACK
#endif
#ifdef GEN_PASS_REGISTRATION
inline void registerBufferDeallocation() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createBufferDeallocationPass();
});
}
inline void registerBufferDeallocationPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createBufferDeallocationPass();
});
}
inline void registerBufferDeallocationSimplification() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createBufferDeallocationSimplificationPass();
});
}
inline void registerBufferDeallocationSimplificationPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createBufferDeallocationSimplificationPass();
});
}
inline void registerBufferHoisting() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createBufferHoistingPass();
});
}
inline void registerBufferHoistingPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createBufferHoistingPass();
});
}
inline void registerBufferLoopHoisting() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createBufferLoopHoistingPass();
});
}
inline void registerBufferLoopHoistingPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createBufferLoopHoistingPass();
});
}
inline void registerBufferResultsToOutParams() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createBufferResultsToOutParamsPass();
});
}
inline void registerBufferResultsToOutParamsPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createBufferResultsToOutParamsPass();
});
}
inline void registerDropEquivalentBufferResults() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createDropEquivalentBufferResultsPass();
});
}
inline void registerDropEquivalentBufferResultsPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createDropEquivalentBufferResultsPass();
});
}
inline void registerEmptyTensorElimination() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createEmptyTensorEliminationPass();
});
}
inline void registerEmptyTensorEliminationPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createEmptyTensorEliminationPass();
});
}
inline void registerEmptyTensorToAllocTensor() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createEmptyTensorToAllocTensorPass();
});
}
inline void registerEmptyTensorToAllocTensorPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createEmptyTensorToAllocTensorPass();
});
}
inline void registerFinalizingBufferize() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createFinalizingBufferizePass();
});
}
inline void registerFinalizingBufferizePass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createFinalizingBufferizePass();
});
}
inline void registerLowerDeallocations() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createLowerDeallocationsPass();
});
}
inline void registerLowerDeallocationsPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createLowerDeallocationsPass();
});
}
inline void registerOneShotBufferize() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createOneShotBufferizePass();
});
}
inline void registerOneShotBufferizePass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createOneShotBufferizePass();
});
}
inline void registerOptimizeAllocationLiveness() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createOptimizeAllocationLivenessPass();
});
}
inline void registerOptimizeAllocationLivenessPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createOptimizeAllocationLivenessPass();
});
}
inline void registerOwnershipBasedBufferDeallocation() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createOwnershipBasedBufferDeallocationPass();
});
}
inline void registerOwnershipBasedBufferDeallocationPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createOwnershipBasedBufferDeallocationPass();
});
}
inline void registerPromoteBuffersToStack() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createPromoteBuffersToStackPass();
});
}
inline void registerPromoteBuffersToStackPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::bufferization::createPromoteBuffersToStackPass();
});
}
inline void registerBufferizationPasses() {
registerBufferDeallocation();
registerBufferDeallocationSimplification();
registerBufferHoisting();
registerBufferLoopHoisting();
registerBufferResultsToOutParams();
registerDropEquivalentBufferResults();
registerEmptyTensorElimination();
registerEmptyTensorToAllocTensor();
registerFinalizingBufferize();
registerLowerDeallocations();
registerOneShotBufferize();
registerOptimizeAllocationLiveness();
registerOwnershipBasedBufferDeallocation();
registerPromoteBuffersToStack();
}
#undef GEN_PASS_REGISTRATION
#endif
#ifdef GEN_PASS_CLASSES
template <typename DerivedT>
class BufferDeallocationBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = BufferDeallocationBase;
BufferDeallocationBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
BufferDeallocationBase(const BufferDeallocationBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
BufferDeallocationBase& operator=(const BufferDeallocationBase &) = delete;
BufferDeallocationBase(BufferDeallocationBase &&) = delete;
BufferDeallocationBase& operator=(BufferDeallocationBase &&) = delete;
~BufferDeallocationBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("buffer-deallocation");
}
::llvm::StringRef getArgument() const override { return "buffer-deallocation"; }
::llvm::StringRef getDescription() const override { return "Adds all required dealloc operations for all allocations in the input program"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("BufferDeallocation");
}
::llvm::StringRef getName() const override { return "BufferDeallocation"; }
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(BufferDeallocationBase<DerivedT>)
protected:
};
template <typename DerivedT>
class BufferDeallocationSimplificationBase : public ::mlir::OperationPass<> {
public:
using Base = BufferDeallocationSimplificationBase;
BufferDeallocationSimplificationBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
BufferDeallocationSimplificationBase(const BufferDeallocationSimplificationBase &other) : ::mlir::OperationPass<>(other) {}
BufferDeallocationSimplificationBase& operator=(const BufferDeallocationSimplificationBase &) = delete;
BufferDeallocationSimplificationBase(BufferDeallocationSimplificationBase &&) = delete;
BufferDeallocationSimplificationBase& operator=(BufferDeallocationSimplificationBase &&) = delete;
~BufferDeallocationSimplificationBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("buffer-deallocation-simplification");
}
::llvm::StringRef getArgument() const override { return "buffer-deallocation-simplification"; }
::llvm::StringRef getDescription() const override { return "Optimizes `bufferization.dealloc` operation for more efficient codegen"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("BufferDeallocationSimplification");
}
::llvm::StringRef getName() const override { return "BufferDeallocationSimplification"; }
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::bufferization::BufferizationDialect>();
registry.insert<mlir::arith::ArithDialect>();
registry.insert<mlir::memref::MemRefDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(BufferDeallocationSimplificationBase<DerivedT>)
protected:
};
template <typename DerivedT>
class BufferHoistingBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = BufferHoistingBase;
BufferHoistingBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
BufferHoistingBase(const BufferHoistingBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
BufferHoistingBase& operator=(const BufferHoistingBase &) = delete;
BufferHoistingBase(BufferHoistingBase &&) = delete;
BufferHoistingBase& operator=(BufferHoistingBase &&) = delete;
~BufferHoistingBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("buffer-hoisting");
}
::llvm::StringRef getArgument() const override { return "buffer-hoisting"; }
::llvm::StringRef getDescription() const override { return "Optimizes placement of allocation operations by moving them into common dominators and out of nested regions"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("BufferHoisting");
}
::llvm::StringRef getName() const override { return "BufferHoisting"; }
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(BufferHoistingBase<DerivedT>)
protected:
};
template <typename DerivedT>
class BufferLoopHoistingBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = BufferLoopHoistingBase;
BufferLoopHoistingBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
BufferLoopHoistingBase(const BufferLoopHoistingBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
BufferLoopHoistingBase& operator=(const BufferLoopHoistingBase &) = delete;
BufferLoopHoistingBase(BufferLoopHoistingBase &&) = delete;
BufferLoopHoistingBase& operator=(BufferLoopHoistingBase &&) = delete;
~BufferLoopHoistingBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("buffer-loop-hoisting");
}
::llvm::StringRef getArgument() const override { return "buffer-loop-hoisting"; }
::llvm::StringRef getDescription() const override { return "Optimizes placement of allocation operations by moving them out of loop nests"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("BufferLoopHoisting");
}
::llvm::StringRef getName() const override { return "BufferLoopHoisting"; }
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(BufferLoopHoistingBase<DerivedT>)
protected:
};
template <typename DerivedT>
class BufferResultsToOutParamsBase : public ::mlir::OperationPass<ModuleOp> {
public:
using Base = BufferResultsToOutParamsBase;
BufferResultsToOutParamsBase() : ::mlir::OperationPass<ModuleOp>(::mlir::TypeID::get<DerivedT>()) {}
BufferResultsToOutParamsBase(const BufferResultsToOutParamsBase &other) : ::mlir::OperationPass<ModuleOp>(other) {}
BufferResultsToOutParamsBase& operator=(const BufferResultsToOutParamsBase &) = delete;
BufferResultsToOutParamsBase(BufferResultsToOutParamsBase &&) = delete;
BufferResultsToOutParamsBase& operator=(BufferResultsToOutParamsBase &&) = delete;
~BufferResultsToOutParamsBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("buffer-results-to-out-params");
}
::llvm::StringRef getArgument() const override { return "buffer-results-to-out-params"; }
::llvm::StringRef getDescription() const override { return "Converts memref-typed function results to out-params"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("BufferResultsToOutParams");
}
::llvm::StringRef getName() const override { return "BufferResultsToOutParams"; }
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<memref::MemRefDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(BufferResultsToOutParamsBase<DerivedT>)
protected:
::mlir::Pass::Option<bool> addResultAttribute{*this, "add-result-attr", ::llvm::cl::desc("Add the attribute 'bufferize.result' to all output parameters."), ::llvm::cl::init(false)};
::mlir::Pass::Option<bool> hoistStaticAllocs{*this, "hoist-static-allocs", ::llvm::cl::desc("Hoist static allocations to call sites."), ::llvm::cl::init(false)};
};
template <typename DerivedT>
class DropEquivalentBufferResultsBase : public ::mlir::OperationPass<ModuleOp> {
public:
using Base = DropEquivalentBufferResultsBase;
DropEquivalentBufferResultsBase() : ::mlir::OperationPass<ModuleOp>(::mlir::TypeID::get<DerivedT>()) {}
DropEquivalentBufferResultsBase(const DropEquivalentBufferResultsBase &other) : ::mlir::OperationPass<ModuleOp>(other) {}
DropEquivalentBufferResultsBase& operator=(const DropEquivalentBufferResultsBase &) = delete;
DropEquivalentBufferResultsBase(DropEquivalentBufferResultsBase &&) = delete;
DropEquivalentBufferResultsBase& operator=(DropEquivalentBufferResultsBase &&) = delete;
~DropEquivalentBufferResultsBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("drop-equivalent-buffer-results");
}
::llvm::StringRef getArgument() const override { return "drop-equivalent-buffer-results"; }
::llvm::StringRef getDescription() const override { return "Remove MemRef return values that are equivalent to a bbArg"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("DropEquivalentBufferResults");
}
::llvm::StringRef getName() const override { return "DropEquivalentBufferResults"; }
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<memref::MemRefDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(DropEquivalentBufferResultsBase<DerivedT>)
protected:
};
template <typename DerivedT>
class EmptyTensorEliminationBase : public ::mlir::OperationPass<> {
public:
using Base = EmptyTensorEliminationBase;
EmptyTensorEliminationBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
EmptyTensorEliminationBase(const EmptyTensorEliminationBase &other) : ::mlir::OperationPass<>(other) {}
EmptyTensorEliminationBase& operator=(const EmptyTensorEliminationBase &) = delete;
EmptyTensorEliminationBase(EmptyTensorEliminationBase &&) = delete;
EmptyTensorEliminationBase& operator=(EmptyTensorEliminationBase &&) = delete;
~EmptyTensorEliminationBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("eliminate-empty-tensors");
}
::llvm::StringRef getArgument() const override { return "eliminate-empty-tensors"; }
::llvm::StringRef getDescription() const override { return "Try to eliminate all tensor.empty ops."; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("EmptyTensorElimination");
}
::llvm::StringRef getName() const override { return "EmptyTensorElimination"; }
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(EmptyTensorEliminationBase<DerivedT>)
protected:
};
template <typename DerivedT>
class EmptyTensorToAllocTensorBase : public ::mlir::OperationPass<> {
public:
using Base = EmptyTensorToAllocTensorBase;
EmptyTensorToAllocTensorBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
EmptyTensorToAllocTensorBase(const EmptyTensorToAllocTensorBase &other) : ::mlir::OperationPass<>(other) {}
EmptyTensorToAllocTensorBase& operator=(const EmptyTensorToAllocTensorBase &) = delete;
EmptyTensorToAllocTensorBase(EmptyTensorToAllocTensorBase &&) = delete;
EmptyTensorToAllocTensorBase& operator=(EmptyTensorToAllocTensorBase &&) = delete;
~EmptyTensorToAllocTensorBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("empty-tensor-to-alloc-tensor");
}
::llvm::StringRef getArgument() const override { return "empty-tensor-to-alloc-tensor"; }
::llvm::StringRef getDescription() const override { return "Replace all empty ops by alloc_tensor ops."; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("EmptyTensorToAllocTensor");
}
::llvm::StringRef getName() const override { return "EmptyTensorToAllocTensor"; }
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<tensor::TensorDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(EmptyTensorToAllocTensorBase<DerivedT>)
protected:
};
template <typename DerivedT>
class FinalizingBufferizeBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = FinalizingBufferizeBase;
FinalizingBufferizeBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
FinalizingBufferizeBase(const FinalizingBufferizeBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
FinalizingBufferizeBase& operator=(const FinalizingBufferizeBase &) = delete;
FinalizingBufferizeBase(FinalizingBufferizeBase &&) = delete;
FinalizingBufferizeBase& operator=(FinalizingBufferizeBase &&) = delete;
~FinalizingBufferizeBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("finalizing-bufferize");
}
::llvm::StringRef getArgument() const override { return "finalizing-bufferize"; }
::llvm::StringRef getDescription() const override { return "Finalize a partial bufferization"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("FinalizingBufferize");
}
::llvm::StringRef getName() const override { return "FinalizingBufferize"; }
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(FinalizingBufferizeBase<DerivedT>)
protected:
};
template <typename DerivedT>
class LowerDeallocationsBase : public ::mlir::OperationPass<> {
public:
using Base = LowerDeallocationsBase;
LowerDeallocationsBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
LowerDeallocationsBase(const LowerDeallocationsBase &other) : ::mlir::OperationPass<>(other) {}
LowerDeallocationsBase& operator=(const LowerDeallocationsBase &) = delete;
LowerDeallocationsBase(LowerDeallocationsBase &&) = delete;
LowerDeallocationsBase& operator=(LowerDeallocationsBase &&) = delete;
~LowerDeallocationsBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("bufferization-lower-deallocations");
}
::llvm::StringRef getArgument() const override { return "bufferization-lower-deallocations"; }
::llvm::StringRef getDescription() const override { return "Lowers `bufferization.dealloc` operations to `memref.dealloc`operations"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("LowerDeallocations");
}
::llvm::StringRef getName() const override { return "LowerDeallocations"; }
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<arith::ArithDialect>();
registry.insert<memref::MemRefDialect>();
registry.insert<scf::SCFDialect>();
registry.insert<func::FuncDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(LowerDeallocationsBase<DerivedT>)
protected:
};
template <typename DerivedT>
class OneShotBufferizeBase : public ::mlir::OperationPass<ModuleOp> {
public:
using Base = OneShotBufferizeBase;
OneShotBufferizeBase() : ::mlir::OperationPass<ModuleOp>(::mlir::TypeID::get<DerivedT>()) {}
OneShotBufferizeBase(const OneShotBufferizeBase &other) : ::mlir::OperationPass<ModuleOp>(other) {}
OneShotBufferizeBase& operator=(const OneShotBufferizeBase &) = delete;
OneShotBufferizeBase(OneShotBufferizeBase &&) = delete;
OneShotBufferizeBase& operator=(OneShotBufferizeBase &&) = delete;
~OneShotBufferizeBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("one-shot-bufferize");
}
::llvm::StringRef getArgument() const override { return "one-shot-bufferize"; }
::llvm::StringRef getDescription() const override { return "One-Shot Bufferize"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("OneShotBufferize");
}
::llvm::StringRef getName() const override { return "OneShotBufferize"; }
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(OneShotBufferizeBase<DerivedT>)
protected:
::mlir::Pass::Option<bool> allowReturnAllocsFromLoops{*this, "allow-return-allocs-from-loops", ::llvm::cl::desc("Allows returning/yielding new allocations from a loop."), ::llvm::cl::init(false)};
::mlir::Pass::Option<bool> allowUnknownOps{*this, "allow-unknown-ops", ::llvm::cl::desc("Allows unknown (not bufferizable) ops in the input IR."), ::llvm::cl::init(false)};
::mlir::Pass::Option<unsigned> analysisFuzzerSeed{*this, "analysis-fuzzer-seed", ::llvm::cl::desc("Test only: Analyze ops in random order with a given seed (fuzzer)"), ::llvm::cl::init(0)};
::mlir::Pass::Option<std::string> analysisHeuristic{*this, "analysis-heuristic", ::llvm::cl::desc("Heuristic that control the IR traversal during analysis"), ::llvm::cl::init("bottom-up")};
::mlir::Pass::Option<bool> bufferizeFunctionBoundaries{*this, "bufferize-function-boundaries", ::llvm::cl::desc("Bufferize function boundaries (experimental)."), ::llvm::cl::init(0)};
::mlir::Pass::Option<bool> checkParallelRegions{*this, "check-parallel-regions", ::llvm::cl::desc("Account for parallel regions in RaW analysis."), ::llvm::cl::init(true)};
::mlir::Pass::Option<bool> copyBeforeWrite{*this, "copy-before-write", ::llvm::cl::desc("Skip the analysis. Make a buffer copy on every write."), ::llvm::cl::init(false)};
::mlir::Pass::ListOption<std::string> dialectFilter{*this, "dialect-filter", ::llvm::cl::desc("Restrict bufferization to ops from these dialects.")};
::mlir::Pass::Option<bool> dumpAliasSets{*this, "dump-alias-sets", ::llvm::cl::desc("Test only: Annotate tensor IR with alias sets"), ::llvm::cl::init(false)};
::mlir::Pass::ListOption<std::string> noAnalysisFuncFilter{*this, "no-analysis-func-filter", ::llvm::cl::desc("Skip analysis of functions with these symbol names.Set copyBeforeWrite to true when bufferizing them.")};
::mlir::Pass::Option<std::string> functionBoundaryTypeConversion{*this, "function-boundary-type-conversion", ::llvm::cl::desc("Controls layout maps when bufferizing function signatures."), ::llvm::cl::init("infer-layout-map")};
::mlir::Pass::Option<bool> mustInferMemorySpace{*this, "must-infer-memory-space", ::llvm::cl::desc("The memory space of an memref types must always be inferred. If unset, a default memory space of 0 is used otherwise."), ::llvm::cl::init(false)};
::mlir::Pass::Option<bool> testAnalysisOnly{*this, "test-analysis-only", ::llvm::cl::desc("Test only: Only run inplaceability analysis and annotate IR"), ::llvm::cl::init(false)};
::mlir::Pass::Option<bool> printConflicts{*this, "print-conflicts", ::llvm::cl::desc("Test only: Annotate IR with RaW conflicts. Requires test-analysis-only."), ::llvm::cl::init(false)};
::mlir::Pass::Option<std::string> unknownTypeConversion{*this, "unknown-type-conversion", ::llvm::cl::desc("Controls layout maps for non-inferrable memref types."), ::llvm::cl::init("fully-dynamic-layout-map")};
::mlir::Pass::Statistic numBufferAlloc{this, "num-buffer-alloc", "Number of buffer allocations"};
::mlir::Pass::Statistic numTensorInPlace{this, "num-tensor-in-place", "Number of in-place tensor OpOperands"};
::mlir::Pass::Statistic numTensorOutOfPlace{this, "num-tensor-out-of-place", "Number of out-of-place tensor OpOperands"};
};
template <typename DerivedT>
class OptimizeAllocationLivenessBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = OptimizeAllocationLivenessBase;
OptimizeAllocationLivenessBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
OptimizeAllocationLivenessBase(const OptimizeAllocationLivenessBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
OptimizeAllocationLivenessBase& operator=(const OptimizeAllocationLivenessBase &) = delete;
OptimizeAllocationLivenessBase(OptimizeAllocationLivenessBase &&) = delete;
OptimizeAllocationLivenessBase& operator=(OptimizeAllocationLivenessBase &&) = delete;
~OptimizeAllocationLivenessBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("optimize-allocation-liveness");
}
::llvm::StringRef getArgument() const override { return "optimize-allocation-liveness"; }
::llvm::StringRef getDescription() const override { return "This pass optimizes the liveness of temp allocations in the input function"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("OptimizeAllocationLiveness");
}
::llvm::StringRef getName() const override { return "OptimizeAllocationLiveness"; }
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::memref::MemRefDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(OptimizeAllocationLivenessBase<DerivedT>)
protected:
};
template <typename DerivedT>
class OwnershipBasedBufferDeallocationBase : public ::mlir::OperationPass<> {
public:
using Base = OwnershipBasedBufferDeallocationBase;
OwnershipBasedBufferDeallocationBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
OwnershipBasedBufferDeallocationBase(const OwnershipBasedBufferDeallocationBase &other) : ::mlir::OperationPass<>(other) {}
OwnershipBasedBufferDeallocationBase& operator=(const OwnershipBasedBufferDeallocationBase &) = delete;
OwnershipBasedBufferDeallocationBase(OwnershipBasedBufferDeallocationBase &&) = delete;
OwnershipBasedBufferDeallocationBase& operator=(OwnershipBasedBufferDeallocationBase &&) = delete;
~OwnershipBasedBufferDeallocationBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("ownership-based-buffer-deallocation");
}
::llvm::StringRef getArgument() const override { return "ownership-based-buffer-deallocation"; }
::llvm::StringRef getDescription() const override { return "Adds all required dealloc operations for all allocations in the input program"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("OwnershipBasedBufferDeallocation");
}
::llvm::StringRef getName() const override { return "OwnershipBasedBufferDeallocation"; }
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::bufferization::BufferizationDialect>();
registry.insert<mlir::arith::ArithDialect>();
registry.insert<mlir::memref::MemRefDialect>();
registry.insert<mlir::scf::SCFDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(OwnershipBasedBufferDeallocationBase<DerivedT>)
protected:
::mlir::Pass::Option<bool> privateFuncDynamicOwnership{*this, "private-function-dynamic-ownership", ::llvm::cl::desc("Allows to add additional arguments to private functions to dynamically pass ownership of memrefs to callees. This can enable earlier deallocations."), ::llvm::cl::init(false)};
};
template <typename DerivedT>
class PromoteBuffersToStackBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = PromoteBuffersToStackBase;
PromoteBuffersToStackBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
PromoteBuffersToStackBase(const PromoteBuffersToStackBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
PromoteBuffersToStackBase& operator=(const PromoteBuffersToStackBase &) = delete;
PromoteBuffersToStackBase(PromoteBuffersToStackBase &&) = delete;
PromoteBuffersToStackBase& operator=(PromoteBuffersToStackBase &&) = delete;
~PromoteBuffersToStackBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("promote-buffers-to-stack");
}
::llvm::StringRef getArgument() const override { return "promote-buffers-to-stack"; }
::llvm::StringRef getDescription() const override { return "Promotes heap-based allocations to automatically managed stack-based allocations"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("PromoteBuffersToStack");
}
::llvm::StringRef getName() const override { return "PromoteBuffersToStack"; }
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(PromoteBuffersToStackBase<DerivedT>)
protected:
::mlir::Pass::Option<unsigned> maxAllocSizeInBytes{*this, "max-alloc-size-in-bytes", ::llvm::cl::desc("Maximal size in bytes to promote allocations to stack."), ::llvm::cl::init(1024)};
::mlir::Pass::Option<unsigned> maxRankOfAllocatedMemRef{*this, "max-rank-of-allocated-memref", ::llvm::cl::desc("Maximal memref rank to promote dynamic buffers."), ::llvm::cl::init(1)};
};
#undef GEN_PASS_CLASSES
#endif