#ifdef GEN_PASS_DECL
#define GEN_PASS_DECL_AFFINEDATACOPYGENERATION
#define GEN_PASS_DECL_AFFINEEXPANDINDEXOPS
#define GEN_PASS_DECL_AFFINELOOPFUSION
#define GEN_PASS_DECL_AFFINELOOPINVARIANTCODEMOTION
#define GEN_PASS_DECL_AFFINELOOPNORMALIZE
#define GEN_PASS_DECL_AFFINELOOPTILING
#define GEN_PASS_DECL_AFFINELOOPUNROLL
#define GEN_PASS_DECL_AFFINELOOPUNROLLANDJAM
#define GEN_PASS_DECL_AFFINEPARALLELIZE
#define GEN_PASS_DECL_AFFINEPIPELINEDATATRANSFER
#define GEN_PASS_DECL_AFFINESCALARREPLACEMENT
#define GEN_PASS_DECL_AFFINEVECTORIZE
#define GEN_PASS_DECL_LOOPCOALESCING
#define GEN_PASS_DECL_SIMPLIFYAFFINESTRUCTURES
#undef GEN_PASS_DECL
#endif
#ifdef GEN_PASS_DECL_AFFINEDATACOPYGENERATION
struct AffineDataCopyGenerationOptions { … };
#undef GEN_PASS_DECL_AFFINEDATACOPYGENERATION
#endif
#ifdef GEN_PASS_DEF_AFFINEDATACOPYGENERATION
namespace impl {
template <typename DerivedT>
class AffineDataCopyGenerationBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffineDataCopyGenerationBase;
AffineDataCopyGenerationBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffineDataCopyGenerationBase(const AffineDataCopyGenerationBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffineDataCopyGenerationBase& operator=(const AffineDataCopyGenerationBase &) = delete;
AffineDataCopyGenerationBase(AffineDataCopyGenerationBase &&) = delete;
AffineDataCopyGenerationBase& operator=(AffineDataCopyGenerationBase &&) = delete;
~AffineDataCopyGenerationBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-data-copy-generate");
}
::llvm::StringRef getArgument() const override { return "affine-data-copy-generate"; }
::llvm::StringRef getDescription() const override { return "Generate explicit copying for affine memory operations"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineDataCopyGeneration");
}
::llvm::StringRef getName() const override { return "AffineDataCopyGeneration"; }
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(AffineDataCopyGenerationBase<DerivedT>)
AffineDataCopyGenerationBase(const AffineDataCopyGenerationOptions &options) : AffineDataCopyGenerationBase() {
fastMemoryCapacity = options.fastMemoryCapacity;
fastMemorySpace = options.fastMemorySpace;
generateDma = options.generateDma;
minDmaTransferSize = options.minDmaTransferSize;
slowMemorySpace = options.slowMemorySpace;
skipNonUnitStrideLoops = options.skipNonUnitStrideLoops;
tagMemorySpace = options.tagMemorySpace;
}
protected:
::mlir::Pass::Option<uint64_t> fastMemoryCapacity{*this, "fast-mem-capacity", ::llvm::cl::desc("Set fast memory space capacity in KiB (default: unlimited)"), ::llvm::cl::init(std::numeric_limits<uint64_t>::max())};
::mlir::Pass::Option<unsigned> fastMemorySpace{*this, "fast-mem-space", ::llvm::cl::desc("Fast memory space identifier for copy generation (default: 1)"), ::llvm::cl::init(1)};
::mlir::Pass::Option<bool> generateDma{*this, "generate-dma", ::llvm::cl::desc("Generate DMA instead of point-wise copy"), ::llvm::cl::init(true)};
::mlir::Pass::Option<int> minDmaTransferSize{*this, "min-dma-transfer", ::llvm::cl::desc("Minimum DMA transfer size supported by the target in bytes"), ::llvm::cl::init(1024)};
::mlir::Pass::Option<unsigned> slowMemorySpace{*this, "slow-mem-space", ::llvm::cl::desc("Slow memory space identifier for copy generation (default: 0)"), ::llvm::cl::init(0)};
::mlir::Pass::Option<bool> skipNonUnitStrideLoops{*this, "skip-non-unit-stride-loops", ::llvm::cl::desc("Testing purposes: avoid non-unit stride loop choice depths for copy placement"), ::llvm::cl::init(false)};
::mlir::Pass::Option<unsigned> tagMemorySpace{*this, "tag-mem-space", ::llvm::cl::desc("Tag memory space identifier for copy generation (default: 0)"), ::llvm::cl::init(0)};
private:
};
}
#undef GEN_PASS_DEF_AFFINEDATACOPYGENERATION
#endif
#ifdef GEN_PASS_DECL_AFFINEEXPANDINDEXOPS
#undef GEN_PASS_DECL_AFFINEEXPANDINDEXOPS
#endif
#ifdef GEN_PASS_DEF_AFFINEEXPANDINDEXOPS
namespace impl {
template <typename DerivedT>
class AffineExpandIndexOpsBase : public ::mlir::OperationPass<> {
public:
using Base = AffineExpandIndexOpsBase;
AffineExpandIndexOpsBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
AffineExpandIndexOpsBase(const AffineExpandIndexOpsBase &other) : ::mlir::OperationPass<>(other) {}
AffineExpandIndexOpsBase& operator=(const AffineExpandIndexOpsBase &) = delete;
AffineExpandIndexOpsBase(AffineExpandIndexOpsBase &&) = delete;
AffineExpandIndexOpsBase& operator=(AffineExpandIndexOpsBase &&) = delete;
~AffineExpandIndexOpsBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-expand-index-ops");
}
::llvm::StringRef getArgument() const override { return "affine-expand-index-ops"; }
::llvm::StringRef getDescription() const override { return "Lower affine operations operating on indices into more fundamental operations"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineExpandIndexOps");
}
::llvm::StringRef getName() const override { return "AffineExpandIndexOps"; }
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(AffineExpandIndexOpsBase<DerivedT>)
protected:
private:
};
}
#undef GEN_PASS_DEF_AFFINEEXPANDINDEXOPS
#endif
#ifdef GEN_PASS_DECL_AFFINELOOPFUSION
struct AffineLoopFusionOptions { … };
#undef GEN_PASS_DECL_AFFINELOOPFUSION
#endif
#ifdef GEN_PASS_DEF_AFFINELOOPFUSION
namespace impl {
template <typename DerivedT>
class AffineLoopFusionBase : public ::mlir::OperationPass<> {
public:
using Base = AffineLoopFusionBase;
AffineLoopFusionBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
AffineLoopFusionBase(const AffineLoopFusionBase &other) : ::mlir::OperationPass<>(other) {}
AffineLoopFusionBase& operator=(const AffineLoopFusionBase &) = delete;
AffineLoopFusionBase(AffineLoopFusionBase &&) = delete;
AffineLoopFusionBase& operator=(AffineLoopFusionBase &&) = delete;
~AffineLoopFusionBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-loop-fusion");
}
::llvm::StringRef getArgument() const override { return "affine-loop-fusion"; }
::llvm::StringRef getDescription() const override { return "Fuse affine loop nests"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineLoopFusion");
}
::llvm::StringRef getName() const override { return "AffineLoopFusion"; }
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(AffineLoopFusionBase<DerivedT>)
AffineLoopFusionBase(const AffineLoopFusionOptions &options) : AffineLoopFusionBase() {
computeToleranceThreshold = options.computeToleranceThreshold;
fastMemorySpace = options.fastMemorySpace;
localBufSizeThreshold = options.localBufSizeThreshold;
maximalFusion = options.maximalFusion;
affineFusionMode = options.affineFusionMode;
}
protected:
::mlir::Pass::Option<double> computeToleranceThreshold{*this, "fusion-compute-tolerance", ::llvm::cl::desc("Fractional increase in additional computation tolerated while fusing"), ::llvm::cl::init(0.30f)};
::mlir::Pass::Option<unsigned> fastMemorySpace{*this, "fusion-fast-mem-space", ::llvm::cl::desc("Faster memory space number to promote fusion buffers to"), ::llvm::cl::init(0)};
::mlir::Pass::Option<uint64_t> localBufSizeThreshold{*this, "fusion-local-buf-threshold", ::llvm::cl::desc("Threshold size (KiB) for promoting local buffers to fast memory space"), ::llvm::cl::init(0)};
::mlir::Pass::Option<bool> maximalFusion{*this, "fusion-maximal", ::llvm::cl::desc("Enables maximal loop fusion"), ::llvm::cl::init(false)};
::mlir::Pass::Option<enum FusionMode> affineFusionMode{*this, "mode", ::llvm::cl::desc("fusion mode to attempt"), ::llvm::cl::init(mlir::affine::FusionMode::Greedy), llvm::cl::values(clEnumValN(mlir::affine::FusionMode::Greedy, "greedy", "Perform greedy (both producer-consumer and sibling) fusion"), clEnumValN( mlir::affine::FusionMode::ProducerConsumer, "producer", "Perform only producer-consumer fusion"), clEnumValN( mlir::affine::FusionMode::Sibling, "sibling", "Perform only sibling fusion"))};
private:
};
}
#undef GEN_PASS_DEF_AFFINELOOPFUSION
#endif
#ifdef GEN_PASS_DECL_AFFINELOOPINVARIANTCODEMOTION
#undef GEN_PASS_DECL_AFFINELOOPINVARIANTCODEMOTION
#endif
#ifdef GEN_PASS_DEF_AFFINELOOPINVARIANTCODEMOTION
namespace impl {
template <typename DerivedT>
class AffineLoopInvariantCodeMotionBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffineLoopInvariantCodeMotionBase;
AffineLoopInvariantCodeMotionBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffineLoopInvariantCodeMotionBase(const AffineLoopInvariantCodeMotionBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffineLoopInvariantCodeMotionBase& operator=(const AffineLoopInvariantCodeMotionBase &) = delete;
AffineLoopInvariantCodeMotionBase(AffineLoopInvariantCodeMotionBase &&) = delete;
AffineLoopInvariantCodeMotionBase& operator=(AffineLoopInvariantCodeMotionBase &&) = delete;
~AffineLoopInvariantCodeMotionBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-loop-invariant-code-motion");
}
::llvm::StringRef getArgument() const override { return "affine-loop-invariant-code-motion"; }
::llvm::StringRef getDescription() const override { return "Hoist loop invariant instructions outside of affine loops"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineLoopInvariantCodeMotion");
}
::llvm::StringRef getName() const override { return "AffineLoopInvariantCodeMotion"; }
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(AffineLoopInvariantCodeMotionBase<DerivedT>)
protected:
private:
};
}
#undef GEN_PASS_DEF_AFFINELOOPINVARIANTCODEMOTION
#endif
#ifdef GEN_PASS_DECL_AFFINELOOPNORMALIZE
struct AffineLoopNormalizeOptions { … };
#undef GEN_PASS_DECL_AFFINELOOPNORMALIZE
#endif
#ifdef GEN_PASS_DEF_AFFINELOOPNORMALIZE
namespace impl {
template <typename DerivedT>
class AffineLoopNormalizeBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffineLoopNormalizeBase;
AffineLoopNormalizeBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffineLoopNormalizeBase(const AffineLoopNormalizeBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffineLoopNormalizeBase& operator=(const AffineLoopNormalizeBase &) = delete;
AffineLoopNormalizeBase(AffineLoopNormalizeBase &&) = delete;
AffineLoopNormalizeBase& operator=(AffineLoopNormalizeBase &&) = delete;
~AffineLoopNormalizeBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-loop-normalize");
}
::llvm::StringRef getArgument() const override { return "affine-loop-normalize"; }
::llvm::StringRef getDescription() const override { return "Apply normalization transformations to affine loop-like ops"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineLoopNormalize");
}
::llvm::StringRef getName() const override { return "AffineLoopNormalize"; }
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(AffineLoopNormalizeBase<DerivedT>)
AffineLoopNormalizeBase(const AffineLoopNormalizeOptions &options) : AffineLoopNormalizeBase() {
promoteSingleIter = options.promoteSingleIter;
}
protected:
::mlir::Pass::Option<bool> promoteSingleIter{*this, "promote-single-iter", ::llvm::cl::desc("Promote single iteration loops"), ::llvm::cl::init(true)};
private:
};
}
#undef GEN_PASS_DEF_AFFINELOOPNORMALIZE
#endif
#ifdef GEN_PASS_DECL_AFFINELOOPTILING
struct AffineLoopTilingOptions { … };
#undef GEN_PASS_DECL_AFFINELOOPTILING
#endif
#ifdef GEN_PASS_DEF_AFFINELOOPTILING
namespace impl {
template <typename DerivedT>
class AffineLoopTilingBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffineLoopTilingBase;
AffineLoopTilingBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffineLoopTilingBase(const AffineLoopTilingBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffineLoopTilingBase& operator=(const AffineLoopTilingBase &) = delete;
AffineLoopTilingBase(AffineLoopTilingBase &&) = delete;
AffineLoopTilingBase& operator=(AffineLoopTilingBase &&) = delete;
~AffineLoopTilingBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-loop-tile");
}
::llvm::StringRef getArgument() const override { return "affine-loop-tile"; }
::llvm::StringRef getDescription() const override { return "Tile affine loop nests"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineLoopTiling");
}
::llvm::StringRef getName() const override { return "AffineLoopTiling"; }
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(AffineLoopTilingBase<DerivedT>)
AffineLoopTilingBase(const AffineLoopTilingOptions &options) : AffineLoopTilingBase() {
cacheSizeInKiB = options.cacheSizeInKiB;
separate = options.separate;
tileSize = options.tileSize;
tileSizes = options.tileSizes;
}
protected:
::mlir::Pass::Option<uint64_t> cacheSizeInKiB{*this, "cache-size", ::llvm::cl::desc("Set size of cache to tile for in KiB (default: 512)"), ::llvm::cl::init(512)};
::mlir::Pass::Option<bool> separate{*this, "separate", ::llvm::cl::desc("Separate full and partial tiles (default: false)"), ::llvm::cl::init(false)};
::mlir::Pass::Option<unsigned> tileSize{*this, "tile-size", ::llvm::cl::desc("Use this tile size for all loops")};
::mlir::Pass::ListOption<unsigned> tileSizes{*this, "tile-sizes", ::llvm::cl::desc("List of tile sizes for each perfect nest (overridden by -tile-size)")};
private:
};
}
#undef GEN_PASS_DEF_AFFINELOOPTILING
#endif
#ifdef GEN_PASS_DECL_AFFINELOOPUNROLL
struct AffineLoopUnrollOptions { … };
#undef GEN_PASS_DECL_AFFINELOOPUNROLL
#endif
#ifdef GEN_PASS_DEF_AFFINELOOPUNROLL
namespace impl {
template <typename DerivedT>
class AffineLoopUnrollBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffineLoopUnrollBase;
AffineLoopUnrollBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffineLoopUnrollBase(const AffineLoopUnrollBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffineLoopUnrollBase& operator=(const AffineLoopUnrollBase &) = delete;
AffineLoopUnrollBase(AffineLoopUnrollBase &&) = delete;
AffineLoopUnrollBase& operator=(AffineLoopUnrollBase &&) = delete;
~AffineLoopUnrollBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-loop-unroll");
}
::llvm::StringRef getArgument() const override { return "affine-loop-unroll"; }
::llvm::StringRef getDescription() const override { return "Unroll affine loops"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineLoopUnroll");
}
::llvm::StringRef getName() const override { return "AffineLoopUnroll"; }
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(AffineLoopUnrollBase<DerivedT>)
AffineLoopUnrollBase(const AffineLoopUnrollOptions &options) : AffineLoopUnrollBase() {
unrollFactor = options.unrollFactor;
unrollUpToFactor = options.unrollUpToFactor;
unrollFull = options.unrollFull;
numRepetitions = options.numRepetitions;
unrollFullThreshold = options.unrollFullThreshold;
cleanUpUnroll = options.cleanUpUnroll;
}
protected:
::mlir::Pass::Option<unsigned> unrollFactor{*this, "unroll-factor", ::llvm::cl::desc("Use this unroll factor for all loops being unrolled"), ::llvm::cl::init(4)};
::mlir::Pass::Option<bool> unrollUpToFactor{*this, "unroll-up-to-factor", ::llvm::cl::desc("Allow unrolling up to the factor specified"), ::llvm::cl::init(false)};
::mlir::Pass::Option<bool> unrollFull{*this, "unroll-full", ::llvm::cl::desc("Fully unroll loops"), ::llvm::cl::init(false)};
::mlir::Pass::Option<unsigned> numRepetitions{*this, "unroll-num-reps", ::llvm::cl::desc("Unroll innermost loops repeatedly this many times"), ::llvm::cl::init(1)};
::mlir::Pass::Option<unsigned> unrollFullThreshold{*this, "unroll-full-threshold", ::llvm::cl::desc("Unroll all loops with trip count less than or equal to this"), ::llvm::cl::init(1)};
::mlir::Pass::Option<bool> cleanUpUnroll{*this, "cleanup-unroll", ::llvm::cl::desc("Fully unroll the cleanup loop when possible."), ::llvm::cl::init(false)};
private:
};
}
#undef GEN_PASS_DEF_AFFINELOOPUNROLL
#endif
#ifdef GEN_PASS_DECL_AFFINELOOPUNROLLANDJAM
struct AffineLoopUnrollAndJamOptions { … };
#undef GEN_PASS_DECL_AFFINELOOPUNROLLANDJAM
#endif
#ifdef GEN_PASS_DEF_AFFINELOOPUNROLLANDJAM
namespace impl {
template <typename DerivedT>
class AffineLoopUnrollAndJamBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffineLoopUnrollAndJamBase;
AffineLoopUnrollAndJamBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffineLoopUnrollAndJamBase(const AffineLoopUnrollAndJamBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffineLoopUnrollAndJamBase& operator=(const AffineLoopUnrollAndJamBase &) = delete;
AffineLoopUnrollAndJamBase(AffineLoopUnrollAndJamBase &&) = delete;
AffineLoopUnrollAndJamBase& operator=(AffineLoopUnrollAndJamBase &&) = delete;
~AffineLoopUnrollAndJamBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-loop-unroll-jam");
}
::llvm::StringRef getArgument() const override { return "affine-loop-unroll-jam"; }
::llvm::StringRef getDescription() const override { return "Unroll and jam affine loops"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineLoopUnrollAndJam");
}
::llvm::StringRef getName() const override { return "AffineLoopUnrollAndJam"; }
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(AffineLoopUnrollAndJamBase<DerivedT>)
AffineLoopUnrollAndJamBase(const AffineLoopUnrollAndJamOptions &options) : AffineLoopUnrollAndJamBase() {
unrollJamFactor = options.unrollJamFactor;
}
protected:
::mlir::Pass::Option<unsigned> unrollJamFactor{*this, "unroll-jam-factor", ::llvm::cl::desc("Use this unroll jam factor for all loops (default 4)"), ::llvm::cl::init(4)};
private:
};
}
#undef GEN_PASS_DEF_AFFINELOOPUNROLLANDJAM
#endif
#ifdef GEN_PASS_DECL_AFFINEPARALLELIZE
struct AffineParallelizeOptions { … };
#undef GEN_PASS_DECL_AFFINEPARALLELIZE
#endif
#ifdef GEN_PASS_DEF_AFFINEPARALLELIZE
namespace impl {
template <typename DerivedT>
class AffineParallelizeBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffineParallelizeBase;
AffineParallelizeBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffineParallelizeBase(const AffineParallelizeBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffineParallelizeBase& operator=(const AffineParallelizeBase &) = delete;
AffineParallelizeBase(AffineParallelizeBase &&) = delete;
AffineParallelizeBase& operator=(AffineParallelizeBase &&) = delete;
~AffineParallelizeBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-parallelize");
}
::llvm::StringRef getArgument() const override { return "affine-parallelize"; }
::llvm::StringRef getDescription() const override { return "Convert affine.for ops into 1-D affine.parallel"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineParallelize");
}
::llvm::StringRef getName() const override { return "AffineParallelize"; }
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(AffineParallelizeBase<DerivedT>)
AffineParallelizeBase(const AffineParallelizeOptions &options) : AffineParallelizeBase() {
maxNested = options.maxNested;
parallelReductions = options.parallelReductions;
}
protected:
::mlir::Pass::Option<unsigned> maxNested{*this, "max-nested", ::llvm::cl::desc("Maximum number of nested parallel loops to produce. Defaults to unlimited (UINT_MAX)."), ::llvm::cl::init(-1u)};
::mlir::Pass::Option<bool> parallelReductions{*this, "parallel-reductions", ::llvm::cl::desc("Whether to parallelize reduction loops. Defaults to false."), ::llvm::cl::init(false)};
private:
};
}
#undef GEN_PASS_DEF_AFFINEPARALLELIZE
#endif
#ifdef GEN_PASS_DECL_AFFINEPIPELINEDATATRANSFER
#undef GEN_PASS_DECL_AFFINEPIPELINEDATATRANSFER
#endif
#ifdef GEN_PASS_DEF_AFFINEPIPELINEDATATRANSFER
namespace impl {
template <typename DerivedT>
class AffinePipelineDataTransferBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffinePipelineDataTransferBase;
AffinePipelineDataTransferBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffinePipelineDataTransferBase(const AffinePipelineDataTransferBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffinePipelineDataTransferBase& operator=(const AffinePipelineDataTransferBase &) = delete;
AffinePipelineDataTransferBase(AffinePipelineDataTransferBase &&) = delete;
AffinePipelineDataTransferBase& operator=(AffinePipelineDataTransferBase &&) = delete;
~AffinePipelineDataTransferBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-pipeline-data-transfer");
}
::llvm::StringRef getArgument() const override { return "affine-pipeline-data-transfer"; }
::llvm::StringRef getDescription() const override { return "Pipeline non-blocking data transfers between explicitly managed levels of the memory hierarchy"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffinePipelineDataTransfer");
}
::llvm::StringRef getName() const override { return "AffinePipelineDataTransfer"; }
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(AffinePipelineDataTransferBase<DerivedT>)
protected:
private:
};
}
#undef GEN_PASS_DEF_AFFINEPIPELINEDATATRANSFER
#endif
#ifdef GEN_PASS_DECL_AFFINESCALARREPLACEMENT
#undef GEN_PASS_DECL_AFFINESCALARREPLACEMENT
#endif
#ifdef GEN_PASS_DEF_AFFINESCALARREPLACEMENT
namespace impl {
template <typename DerivedT>
class AffineScalarReplacementBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffineScalarReplacementBase;
AffineScalarReplacementBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffineScalarReplacementBase(const AffineScalarReplacementBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffineScalarReplacementBase& operator=(const AffineScalarReplacementBase &) = delete;
AffineScalarReplacementBase(AffineScalarReplacementBase &&) = delete;
AffineScalarReplacementBase& operator=(AffineScalarReplacementBase &&) = delete;
~AffineScalarReplacementBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-scalrep");
}
::llvm::StringRef getArgument() const override { return "affine-scalrep"; }
::llvm::StringRef getDescription() const override { return "Replace affine memref accesses by scalars by forwarding stores to loads and eliminating redundant loads"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineScalarReplacement");
}
::llvm::StringRef getName() const override { return "AffineScalarReplacement"; }
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(AffineScalarReplacementBase<DerivedT>)
protected:
private:
};
}
#undef GEN_PASS_DEF_AFFINESCALARREPLACEMENT
#endif
#ifdef GEN_PASS_DECL_AFFINEVECTORIZE
struct AffineVectorizeOptions { … };
std::unique_ptr<::mlir::Pass> createAffineVectorize();
std::unique_ptr<::mlir::Pass> createAffineVectorize(const AffineVectorizeOptions &options);
#undef GEN_PASS_DECL_AFFINEVECTORIZE
#endif
#ifdef GEN_PASS_DEF_AFFINEVECTORIZE
namespace impl {
std::unique_ptr<::mlir::Pass> createAffineVectorize();
}
namespace impl {
std::unique_ptr<::mlir::Pass> createAffineVectorize(const AffineVectorizeOptions &options);
}
namespace impl {
template <typename DerivedT>
class AffineVectorizeBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffineVectorizeBase;
AffineVectorizeBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffineVectorizeBase(const AffineVectorizeBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffineVectorizeBase& operator=(const AffineVectorizeBase &) = delete;
AffineVectorizeBase(AffineVectorizeBase &&) = delete;
AffineVectorizeBase& operator=(AffineVectorizeBase &&) = delete;
~AffineVectorizeBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-super-vectorize");
}
::llvm::StringRef getArgument() const override { return "affine-super-vectorize"; }
::llvm::StringRef getDescription() const override { return "Vectorize to a target independent n-D vector abstraction"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineVectorize");
}
::llvm::StringRef getName() const override { return "AffineVectorize"; }
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<vector::VectorDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(AffineVectorizeBase<DerivedT>)
AffineVectorizeBase(const AffineVectorizeOptions &options) : AffineVectorizeBase() {
vectorSizes = options.vectorSizes;
fastestVaryingPattern = options.fastestVaryingPattern;
vectorizeReductions = options.vectorizeReductions;
}
protected:
::mlir::Pass::ListOption<int64_t> vectorSizes{*this, "virtual-vector-size", ::llvm::cl::desc("Specify an n-D virtual vector size for vectorization. This must be greater than zero.")};
::mlir::Pass::ListOption<int64_t> fastestVaryingPattern{*this, "test-fastest-varying", ::llvm::cl::desc("Specify a 1-D, 2-D or 3-D pattern of fastest varying memory dimensions to match. See defaultPatterns in Vectorize.cpp for a description and examples. This is used for testing purposes")};
::mlir::Pass::Option<bool> vectorizeReductions{*this, "vectorize-reductions", ::llvm::cl::desc("Vectorize known reductions expressed via iter_args. Switched off by default."), ::llvm::cl::init(false)};
private:
friend std::unique_ptr<::mlir::Pass> createAffineVectorize() {
return std::make_unique<DerivedT>();
}
friend std::unique_ptr<::mlir::Pass> createAffineVectorize(const AffineVectorizeOptions &options) {
return std::make_unique<DerivedT>(options);
}
};
}
std::unique_ptr<::mlir::Pass> createAffineVectorize() {
return impl::createAffineVectorize();
}
std::unique_ptr<::mlir::Pass> createAffineVectorize(const AffineVectorizeOptions &options) {
return impl::createAffineVectorize(options);
}
#undef GEN_PASS_DEF_AFFINEVECTORIZE
#endif
#ifdef GEN_PASS_DECL_LOOPCOALESCING
#undef GEN_PASS_DECL_LOOPCOALESCING
#endif
#ifdef GEN_PASS_DEF_LOOPCOALESCING
namespace impl {
template <typename DerivedT>
class LoopCoalescingBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = LoopCoalescingBase;
LoopCoalescingBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
LoopCoalescingBase(const LoopCoalescingBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
LoopCoalescingBase& operator=(const LoopCoalescingBase &) = delete;
LoopCoalescingBase(LoopCoalescingBase &&) = delete;
LoopCoalescingBase& operator=(LoopCoalescingBase &&) = delete;
~LoopCoalescingBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-loop-coalescing");
}
::llvm::StringRef getArgument() const override { return "affine-loop-coalescing"; }
::llvm::StringRef getDescription() const override { return "Coalesce nested loops with independent bounds into a single loop"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("LoopCoalescing");
}
::llvm::StringRef getName() const override { return "LoopCoalescing"; }
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>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(LoopCoalescingBase<DerivedT>)
protected:
private:
};
}
#undef GEN_PASS_DEF_LOOPCOALESCING
#endif
#ifdef GEN_PASS_DECL_SIMPLIFYAFFINESTRUCTURES
#undef GEN_PASS_DECL_SIMPLIFYAFFINESTRUCTURES
#endif
#ifdef GEN_PASS_DEF_SIMPLIFYAFFINESTRUCTURES
namespace impl {
template <typename DerivedT>
class SimplifyAffineStructuresBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = SimplifyAffineStructuresBase;
SimplifyAffineStructuresBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
SimplifyAffineStructuresBase(const SimplifyAffineStructuresBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
SimplifyAffineStructuresBase& operator=(const SimplifyAffineStructuresBase &) = delete;
SimplifyAffineStructuresBase(SimplifyAffineStructuresBase &&) = delete;
SimplifyAffineStructuresBase& operator=(SimplifyAffineStructuresBase &&) = delete;
~SimplifyAffineStructuresBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-simplify-structures");
}
::llvm::StringRef getArgument() const override { return "affine-simplify-structures"; }
::llvm::StringRef getDescription() const override { return "Simplify affine expressions in maps/sets and normalize memrefs"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("SimplifyAffineStructures");
}
::llvm::StringRef getName() const override { return "SimplifyAffineStructures"; }
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(SimplifyAffineStructuresBase<DerivedT>)
protected:
private:
};
}
#undef GEN_PASS_DEF_SIMPLIFYAFFINESTRUCTURES
#endif
#ifdef GEN_PASS_REGISTRATION
inline void registerAffineDataCopyGeneration() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createAffineDataCopyGenerationPass();
});
}
inline void registerAffineDataCopyGenerationPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createAffineDataCopyGenerationPass();
});
}
inline void registerAffineExpandIndexOps() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createAffineExpandIndexOpsPass();
});
}
inline void registerAffineExpandIndexOpsPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createAffineExpandIndexOpsPass();
});
}
inline void registerAffineLoopFusion() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createLoopFusionPass();
});
}
inline void registerAffineLoopFusionPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createLoopFusionPass();
});
}
inline void registerAffineLoopInvariantCodeMotion() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createAffineLoopInvariantCodeMotionPass();
});
}
inline void registerAffineLoopInvariantCodeMotionPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createAffineLoopInvariantCodeMotionPass();
});
}
inline void registerAffineLoopNormalize() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createAffineLoopNormalizePass();
});
}
inline void registerAffineLoopNormalizePass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createAffineLoopNormalizePass();
});
}
inline void registerAffineLoopTiling() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createLoopTilingPass();
});
}
inline void registerAffineLoopTilingPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createLoopTilingPass();
});
}
inline void registerAffineLoopUnroll() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createLoopUnrollPass();
});
}
inline void registerAffineLoopUnrollPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createLoopUnrollPass();
});
}
inline void registerAffineLoopUnrollAndJam() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createLoopUnrollAndJamPass();
});
}
inline void registerAffineLoopUnrollAndJamPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createLoopUnrollAndJamPass();
});
}
inline void registerAffineParallelize() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createAffineParallelizePass();
});
}
inline void registerAffineParallelizePass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createAffineParallelizePass();
});
}
inline void registerAffinePipelineDataTransfer() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createPipelineDataTransferPass();
});
}
inline void registerAffinePipelineDataTransferPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createPipelineDataTransferPass();
});
}
inline void registerAffineScalarReplacement() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createAffineScalarReplacementPass();
});
}
inline void registerAffineScalarReplacementPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createAffineScalarReplacementPass();
});
}
inline void registerAffineVectorize() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return createAffineVectorize();
});
}
inline void registerAffineVectorizePass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return createAffineVectorize();
});
}
inline void registerLoopCoalescing() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createLoopCoalescingPass();
});
}
inline void registerLoopCoalescingPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createLoopCoalescingPass();
});
}
inline void registerSimplifyAffineStructures() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createSimplifyAffineStructuresPass();
});
}
inline void registerSimplifyAffineStructuresPass() {
::mlir::registerPass([]() -> std::unique_ptr<::mlir::Pass> {
return mlir::affine::createSimplifyAffineStructuresPass();
});
}
inline void registerAffinePasses() {
registerAffineDataCopyGeneration();
registerAffineExpandIndexOps();
registerAffineLoopFusion();
registerAffineLoopInvariantCodeMotion();
registerAffineLoopNormalize();
registerAffineLoopTiling();
registerAffineLoopUnroll();
registerAffineLoopUnrollAndJam();
registerAffineParallelize();
registerAffinePipelineDataTransfer();
registerAffineScalarReplacement();
registerAffineVectorize();
registerLoopCoalescing();
registerSimplifyAffineStructures();
}
#undef GEN_PASS_REGISTRATION
#endif
#ifdef GEN_PASS_CLASSES
template <typename DerivedT>
class AffineDataCopyGenerationBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffineDataCopyGenerationBase;
AffineDataCopyGenerationBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffineDataCopyGenerationBase(const AffineDataCopyGenerationBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffineDataCopyGenerationBase& operator=(const AffineDataCopyGenerationBase &) = delete;
AffineDataCopyGenerationBase(AffineDataCopyGenerationBase &&) = delete;
AffineDataCopyGenerationBase& operator=(AffineDataCopyGenerationBase &&) = delete;
~AffineDataCopyGenerationBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-data-copy-generate");
}
::llvm::StringRef getArgument() const override { return "affine-data-copy-generate"; }
::llvm::StringRef getDescription() const override { return "Generate explicit copying for affine memory operations"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineDataCopyGeneration");
}
::llvm::StringRef getName() const override { return "AffineDataCopyGeneration"; }
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(AffineDataCopyGenerationBase<DerivedT>)
protected:
::mlir::Pass::Option<uint64_t> fastMemoryCapacity{*this, "fast-mem-capacity", ::llvm::cl::desc("Set fast memory space capacity in KiB (default: unlimited)"), ::llvm::cl::init(std::numeric_limits<uint64_t>::max())};
::mlir::Pass::Option<unsigned> fastMemorySpace{*this, "fast-mem-space", ::llvm::cl::desc("Fast memory space identifier for copy generation (default: 1)"), ::llvm::cl::init(1)};
::mlir::Pass::Option<bool> generateDma{*this, "generate-dma", ::llvm::cl::desc("Generate DMA instead of point-wise copy"), ::llvm::cl::init(true)};
::mlir::Pass::Option<int> minDmaTransferSize{*this, "min-dma-transfer", ::llvm::cl::desc("Minimum DMA transfer size supported by the target in bytes"), ::llvm::cl::init(1024)};
::mlir::Pass::Option<unsigned> slowMemorySpace{*this, "slow-mem-space", ::llvm::cl::desc("Slow memory space identifier for copy generation (default: 0)"), ::llvm::cl::init(0)};
::mlir::Pass::Option<bool> skipNonUnitStrideLoops{*this, "skip-non-unit-stride-loops", ::llvm::cl::desc("Testing purposes: avoid non-unit stride loop choice depths for copy placement"), ::llvm::cl::init(false)};
::mlir::Pass::Option<unsigned> tagMemorySpace{*this, "tag-mem-space", ::llvm::cl::desc("Tag memory space identifier for copy generation (default: 0)"), ::llvm::cl::init(0)};
};
template <typename DerivedT>
class AffineExpandIndexOpsBase : public ::mlir::OperationPass<> {
public:
using Base = AffineExpandIndexOpsBase;
AffineExpandIndexOpsBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
AffineExpandIndexOpsBase(const AffineExpandIndexOpsBase &other) : ::mlir::OperationPass<>(other) {}
AffineExpandIndexOpsBase& operator=(const AffineExpandIndexOpsBase &) = delete;
AffineExpandIndexOpsBase(AffineExpandIndexOpsBase &&) = delete;
AffineExpandIndexOpsBase& operator=(AffineExpandIndexOpsBase &&) = delete;
~AffineExpandIndexOpsBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-expand-index-ops");
}
::llvm::StringRef getArgument() const override { return "affine-expand-index-ops"; }
::llvm::StringRef getDescription() const override { return "Lower affine operations operating on indices into more fundamental operations"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineExpandIndexOps");
}
::llvm::StringRef getName() const override { return "AffineExpandIndexOps"; }
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(AffineExpandIndexOpsBase<DerivedT>)
protected:
};
template <typename DerivedT>
class AffineLoopFusionBase : public ::mlir::OperationPass<> {
public:
using Base = AffineLoopFusionBase;
AffineLoopFusionBase() : ::mlir::OperationPass<>(::mlir::TypeID::get<DerivedT>()) {}
AffineLoopFusionBase(const AffineLoopFusionBase &other) : ::mlir::OperationPass<>(other) {}
AffineLoopFusionBase& operator=(const AffineLoopFusionBase &) = delete;
AffineLoopFusionBase(AffineLoopFusionBase &&) = delete;
AffineLoopFusionBase& operator=(AffineLoopFusionBase &&) = delete;
~AffineLoopFusionBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-loop-fusion");
}
::llvm::StringRef getArgument() const override { return "affine-loop-fusion"; }
::llvm::StringRef getDescription() const override { return "Fuse affine loop nests"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineLoopFusion");
}
::llvm::StringRef getName() const override { return "AffineLoopFusion"; }
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(AffineLoopFusionBase<DerivedT>)
protected:
::mlir::Pass::Option<double> computeToleranceThreshold{*this, "fusion-compute-tolerance", ::llvm::cl::desc("Fractional increase in additional computation tolerated while fusing"), ::llvm::cl::init(0.30f)};
::mlir::Pass::Option<unsigned> fastMemorySpace{*this, "fusion-fast-mem-space", ::llvm::cl::desc("Faster memory space number to promote fusion buffers to"), ::llvm::cl::init(0)};
::mlir::Pass::Option<uint64_t> localBufSizeThreshold{*this, "fusion-local-buf-threshold", ::llvm::cl::desc("Threshold size (KiB) for promoting local buffers to fast memory space"), ::llvm::cl::init(0)};
::mlir::Pass::Option<bool> maximalFusion{*this, "fusion-maximal", ::llvm::cl::desc("Enables maximal loop fusion"), ::llvm::cl::init(false)};
::mlir::Pass::Option<enum FusionMode> affineFusionMode{*this, "mode", ::llvm::cl::desc("fusion mode to attempt"), ::llvm::cl::init(mlir::affine::FusionMode::Greedy), llvm::cl::values(clEnumValN(mlir::affine::FusionMode::Greedy, "greedy", "Perform greedy (both producer-consumer and sibling) fusion"), clEnumValN( mlir::affine::FusionMode::ProducerConsumer, "producer", "Perform only producer-consumer fusion"), clEnumValN( mlir::affine::FusionMode::Sibling, "sibling", "Perform only sibling fusion"))};
};
template <typename DerivedT>
class AffineLoopInvariantCodeMotionBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffineLoopInvariantCodeMotionBase;
AffineLoopInvariantCodeMotionBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffineLoopInvariantCodeMotionBase(const AffineLoopInvariantCodeMotionBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffineLoopInvariantCodeMotionBase& operator=(const AffineLoopInvariantCodeMotionBase &) = delete;
AffineLoopInvariantCodeMotionBase(AffineLoopInvariantCodeMotionBase &&) = delete;
AffineLoopInvariantCodeMotionBase& operator=(AffineLoopInvariantCodeMotionBase &&) = delete;
~AffineLoopInvariantCodeMotionBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-loop-invariant-code-motion");
}
::llvm::StringRef getArgument() const override { return "affine-loop-invariant-code-motion"; }
::llvm::StringRef getDescription() const override { return "Hoist loop invariant instructions outside of affine loops"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineLoopInvariantCodeMotion");
}
::llvm::StringRef getName() const override { return "AffineLoopInvariantCodeMotion"; }
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(AffineLoopInvariantCodeMotionBase<DerivedT>)
protected:
};
template <typename DerivedT>
class AffineLoopNormalizeBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffineLoopNormalizeBase;
AffineLoopNormalizeBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffineLoopNormalizeBase(const AffineLoopNormalizeBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffineLoopNormalizeBase& operator=(const AffineLoopNormalizeBase &) = delete;
AffineLoopNormalizeBase(AffineLoopNormalizeBase &&) = delete;
AffineLoopNormalizeBase& operator=(AffineLoopNormalizeBase &&) = delete;
~AffineLoopNormalizeBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-loop-normalize");
}
::llvm::StringRef getArgument() const override { return "affine-loop-normalize"; }
::llvm::StringRef getDescription() const override { return "Apply normalization transformations to affine loop-like ops"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineLoopNormalize");
}
::llvm::StringRef getName() const override { return "AffineLoopNormalize"; }
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(AffineLoopNormalizeBase<DerivedT>)
protected:
::mlir::Pass::Option<bool> promoteSingleIter{*this, "promote-single-iter", ::llvm::cl::desc("Promote single iteration loops"), ::llvm::cl::init(true)};
};
template <typename DerivedT>
class AffineLoopTilingBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffineLoopTilingBase;
AffineLoopTilingBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffineLoopTilingBase(const AffineLoopTilingBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffineLoopTilingBase& operator=(const AffineLoopTilingBase &) = delete;
AffineLoopTilingBase(AffineLoopTilingBase &&) = delete;
AffineLoopTilingBase& operator=(AffineLoopTilingBase &&) = delete;
~AffineLoopTilingBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-loop-tile");
}
::llvm::StringRef getArgument() const override { return "affine-loop-tile"; }
::llvm::StringRef getDescription() const override { return "Tile affine loop nests"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineLoopTiling");
}
::llvm::StringRef getName() const override { return "AffineLoopTiling"; }
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(AffineLoopTilingBase<DerivedT>)
protected:
::mlir::Pass::Option<uint64_t> cacheSizeInKiB{*this, "cache-size", ::llvm::cl::desc("Set size of cache to tile for in KiB (default: 512)"), ::llvm::cl::init(512)};
::mlir::Pass::Option<bool> separate{*this, "separate", ::llvm::cl::desc("Separate full and partial tiles (default: false)"), ::llvm::cl::init(false)};
::mlir::Pass::Option<unsigned> tileSize{*this, "tile-size", ::llvm::cl::desc("Use this tile size for all loops")};
::mlir::Pass::ListOption<unsigned> tileSizes{*this, "tile-sizes", ::llvm::cl::desc("List of tile sizes for each perfect nest (overridden by -tile-size)")};
};
template <typename DerivedT>
class AffineLoopUnrollBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffineLoopUnrollBase;
AffineLoopUnrollBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffineLoopUnrollBase(const AffineLoopUnrollBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffineLoopUnrollBase& operator=(const AffineLoopUnrollBase &) = delete;
AffineLoopUnrollBase(AffineLoopUnrollBase &&) = delete;
AffineLoopUnrollBase& operator=(AffineLoopUnrollBase &&) = delete;
~AffineLoopUnrollBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-loop-unroll");
}
::llvm::StringRef getArgument() const override { return "affine-loop-unroll"; }
::llvm::StringRef getDescription() const override { return "Unroll affine loops"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineLoopUnroll");
}
::llvm::StringRef getName() const override { return "AffineLoopUnroll"; }
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(AffineLoopUnrollBase<DerivedT>)
protected:
::mlir::Pass::Option<unsigned> unrollFactor{*this, "unroll-factor", ::llvm::cl::desc("Use this unroll factor for all loops being unrolled"), ::llvm::cl::init(4)};
::mlir::Pass::Option<bool> unrollUpToFactor{*this, "unroll-up-to-factor", ::llvm::cl::desc("Allow unrolling up to the factor specified"), ::llvm::cl::init(false)};
::mlir::Pass::Option<bool> unrollFull{*this, "unroll-full", ::llvm::cl::desc("Fully unroll loops"), ::llvm::cl::init(false)};
::mlir::Pass::Option<unsigned> numRepetitions{*this, "unroll-num-reps", ::llvm::cl::desc("Unroll innermost loops repeatedly this many times"), ::llvm::cl::init(1)};
::mlir::Pass::Option<unsigned> unrollFullThreshold{*this, "unroll-full-threshold", ::llvm::cl::desc("Unroll all loops with trip count less than or equal to this"), ::llvm::cl::init(1)};
::mlir::Pass::Option<bool> cleanUpUnroll{*this, "cleanup-unroll", ::llvm::cl::desc("Fully unroll the cleanup loop when possible."), ::llvm::cl::init(false)};
};
template <typename DerivedT>
class AffineLoopUnrollAndJamBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffineLoopUnrollAndJamBase;
AffineLoopUnrollAndJamBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffineLoopUnrollAndJamBase(const AffineLoopUnrollAndJamBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffineLoopUnrollAndJamBase& operator=(const AffineLoopUnrollAndJamBase &) = delete;
AffineLoopUnrollAndJamBase(AffineLoopUnrollAndJamBase &&) = delete;
AffineLoopUnrollAndJamBase& operator=(AffineLoopUnrollAndJamBase &&) = delete;
~AffineLoopUnrollAndJamBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-loop-unroll-jam");
}
::llvm::StringRef getArgument() const override { return "affine-loop-unroll-jam"; }
::llvm::StringRef getDescription() const override { return "Unroll and jam affine loops"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineLoopUnrollAndJam");
}
::llvm::StringRef getName() const override { return "AffineLoopUnrollAndJam"; }
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(AffineLoopUnrollAndJamBase<DerivedT>)
protected:
::mlir::Pass::Option<unsigned> unrollJamFactor{*this, "unroll-jam-factor", ::llvm::cl::desc("Use this unroll jam factor for all loops (default 4)"), ::llvm::cl::init(4)};
};
template <typename DerivedT>
class AffineParallelizeBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffineParallelizeBase;
AffineParallelizeBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffineParallelizeBase(const AffineParallelizeBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffineParallelizeBase& operator=(const AffineParallelizeBase &) = delete;
AffineParallelizeBase(AffineParallelizeBase &&) = delete;
AffineParallelizeBase& operator=(AffineParallelizeBase &&) = delete;
~AffineParallelizeBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-parallelize");
}
::llvm::StringRef getArgument() const override { return "affine-parallelize"; }
::llvm::StringRef getDescription() const override { return "Convert affine.for ops into 1-D affine.parallel"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineParallelize");
}
::llvm::StringRef getName() const override { return "AffineParallelize"; }
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(AffineParallelizeBase<DerivedT>)
protected:
::mlir::Pass::Option<unsigned> maxNested{*this, "max-nested", ::llvm::cl::desc("Maximum number of nested parallel loops to produce. Defaults to unlimited (UINT_MAX)."), ::llvm::cl::init(-1u)};
::mlir::Pass::Option<bool> parallelReductions{*this, "parallel-reductions", ::llvm::cl::desc("Whether to parallelize reduction loops. Defaults to false."), ::llvm::cl::init(false)};
};
template <typename DerivedT>
class AffinePipelineDataTransferBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffinePipelineDataTransferBase;
AffinePipelineDataTransferBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffinePipelineDataTransferBase(const AffinePipelineDataTransferBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffinePipelineDataTransferBase& operator=(const AffinePipelineDataTransferBase &) = delete;
AffinePipelineDataTransferBase(AffinePipelineDataTransferBase &&) = delete;
AffinePipelineDataTransferBase& operator=(AffinePipelineDataTransferBase &&) = delete;
~AffinePipelineDataTransferBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-pipeline-data-transfer");
}
::llvm::StringRef getArgument() const override { return "affine-pipeline-data-transfer"; }
::llvm::StringRef getDescription() const override { return "Pipeline non-blocking data transfers between explicitly managed levels of the memory hierarchy"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffinePipelineDataTransfer");
}
::llvm::StringRef getName() const override { return "AffinePipelineDataTransfer"; }
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(AffinePipelineDataTransferBase<DerivedT>)
protected:
};
template <typename DerivedT>
class AffineScalarReplacementBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffineScalarReplacementBase;
AffineScalarReplacementBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffineScalarReplacementBase(const AffineScalarReplacementBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffineScalarReplacementBase& operator=(const AffineScalarReplacementBase &) = delete;
AffineScalarReplacementBase(AffineScalarReplacementBase &&) = delete;
AffineScalarReplacementBase& operator=(AffineScalarReplacementBase &&) = delete;
~AffineScalarReplacementBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-scalrep");
}
::llvm::StringRef getArgument() const override { return "affine-scalrep"; }
::llvm::StringRef getDescription() const override { return "Replace affine memref accesses by scalars by forwarding stores to loads and eliminating redundant loads"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineScalarReplacement");
}
::llvm::StringRef getName() const override { return "AffineScalarReplacement"; }
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(AffineScalarReplacementBase<DerivedT>)
protected:
};
template <typename DerivedT>
class AffineVectorizeBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = AffineVectorizeBase;
AffineVectorizeBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
AffineVectorizeBase(const AffineVectorizeBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
AffineVectorizeBase& operator=(const AffineVectorizeBase &) = delete;
AffineVectorizeBase(AffineVectorizeBase &&) = delete;
AffineVectorizeBase& operator=(AffineVectorizeBase &&) = delete;
~AffineVectorizeBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-super-vectorize");
}
::llvm::StringRef getArgument() const override { return "affine-super-vectorize"; }
::llvm::StringRef getDescription() const override { return "Vectorize to a target independent n-D vector abstraction"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("AffineVectorize");
}
::llvm::StringRef getName() const override { return "AffineVectorize"; }
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<vector::VectorDialect>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(AffineVectorizeBase<DerivedT>)
protected:
::mlir::Pass::ListOption<int64_t> vectorSizes{*this, "virtual-vector-size", ::llvm::cl::desc("Specify an n-D virtual vector size for vectorization. This must be greater than zero.")};
::mlir::Pass::ListOption<int64_t> fastestVaryingPattern{*this, "test-fastest-varying", ::llvm::cl::desc("Specify a 1-D, 2-D or 3-D pattern of fastest varying memory dimensions to match. See defaultPatterns in Vectorize.cpp for a description and examples. This is used for testing purposes")};
::mlir::Pass::Option<bool> vectorizeReductions{*this, "vectorize-reductions", ::llvm::cl::desc("Vectorize known reductions expressed via iter_args. Switched off by default."), ::llvm::cl::init(false)};
};
template <typename DerivedT>
class LoopCoalescingBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = LoopCoalescingBase;
LoopCoalescingBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
LoopCoalescingBase(const LoopCoalescingBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
LoopCoalescingBase& operator=(const LoopCoalescingBase &) = delete;
LoopCoalescingBase(LoopCoalescingBase &&) = delete;
LoopCoalescingBase& operator=(LoopCoalescingBase &&) = delete;
~LoopCoalescingBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-loop-coalescing");
}
::llvm::StringRef getArgument() const override { return "affine-loop-coalescing"; }
::llvm::StringRef getDescription() const override { return "Coalesce nested loops with independent bounds into a single loop"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("LoopCoalescing");
}
::llvm::StringRef getName() const override { return "LoopCoalescing"; }
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>();
}
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(LoopCoalescingBase<DerivedT>)
protected:
};
template <typename DerivedT>
class SimplifyAffineStructuresBase : public ::mlir::OperationPass<func::FuncOp> {
public:
using Base = SimplifyAffineStructuresBase;
SimplifyAffineStructuresBase() : ::mlir::OperationPass<func::FuncOp>(::mlir::TypeID::get<DerivedT>()) {}
SimplifyAffineStructuresBase(const SimplifyAffineStructuresBase &other) : ::mlir::OperationPass<func::FuncOp>(other) {}
SimplifyAffineStructuresBase& operator=(const SimplifyAffineStructuresBase &) = delete;
SimplifyAffineStructuresBase(SimplifyAffineStructuresBase &&) = delete;
SimplifyAffineStructuresBase& operator=(SimplifyAffineStructuresBase &&) = delete;
~SimplifyAffineStructuresBase() = default;
static constexpr ::llvm::StringLiteral getArgumentName() {
return ::llvm::StringLiteral("affine-simplify-structures");
}
::llvm::StringRef getArgument() const override { return "affine-simplify-structures"; }
::llvm::StringRef getDescription() const override { return "Simplify affine expressions in maps/sets and normalize memrefs"; }
static constexpr ::llvm::StringLiteral getPassName() {
return ::llvm::StringLiteral("SimplifyAffineStructures");
}
::llvm::StringRef getName() const override { return "SimplifyAffineStructures"; }
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(SimplifyAffineStructuresBase<DerivedT>)
protected:
};
#undef GEN_PASS_CLASSES
#endif