#include "mlir/Dialect/Affine/IR/AffineOps.h"
#include "mlir/Dialect/Func/IR/FuncOps.h"
#include "mlir/Dialect/Linalg/Transforms/Transforms.h"
#include "mlir/Pass/Pass.h"
#include "mlir/Pass/PassManager.h"
#include "mlir/Transforms/GreedyPatternRewriteDriver.h"
using namespace mlir;
namespace {
struct TestLinalgRankReduceContractionOps
: public PassWrapper<TestLinalgRankReduceContractionOps,
OperationPass<func::FuncOp>> {
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(
TestLinalgRankReduceContractionOps)
TestLinalgRankReduceContractionOps() = default;
TestLinalgRankReduceContractionOps(
const TestLinalgRankReduceContractionOps &pass)
: PassWrapper(pass) {}
void getDependentDialects(DialectRegistry ®istry) const override {
registry.insert<affine::AffineDialect, linalg::LinalgDialect,
memref::MemRefDialect, tensor::TensorDialect>();
}
StringRef getArgument() const final {
return "test-linalg-rank-reduce-contraction-ops";
}
StringRef getDescription() const final {
return "Test Linalg rank reduce contraction ops with unit dims";
}
void runOnOperation() override {
MLIRContext *context = &this->getContext();
func::FuncOp funcOp = this->getOperation();
RewritePatternSet patterns(context);
linalg::populateContractionOpRankReducingPatterns(patterns);
if (failed(applyPatternsAndFoldGreedily(funcOp.getBody(),
std::move(patterns))))
return signalPassFailure();
return;
}
};
}
namespace mlir {
namespace test {
void registerTestLinalgRankReduceContractionOps() {
PassRegistration<TestLinalgRankReduceContractionOps>();
}
}
}