19ed1e587SSean Silva //===- ConvertShapeConstraints.cpp - Conversion of shape constraints ------===//
29ed1e587SSean Silva //
39ed1e587SSean Silva // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
49ed1e587SSean Silva // See https://llvm.org/LICENSE.txt for license information.
59ed1e587SSean Silva // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
69ed1e587SSean Silva //
79ed1e587SSean Silva //===----------------------------------------------------------------------===//
89ed1e587SSean Silva
99ed1e587SSean Silva #include "mlir/Conversion/ShapeToStandard/ShapeToStandard.h"
109ed1e587SSean Silva
119ed1e587SSean Silva #include "../PassDetail.h"
12ace01605SRiver Riddle #include "mlir/Dialect/ControlFlow/IR/ControlFlowOps.h"
13*8b68da2cSAlex Zinenko #include "mlir/Dialect/SCF/IR/SCF.h"
149ed1e587SSean Silva #include "mlir/Dialect/Shape/IR/Shape.h"
15444822d7SSean Silva #include "mlir/Dialect/Tensor/IR/Tensor.h"
169ed1e587SSean Silva #include "mlir/IR/PatternMatch.h"
179ed1e587SSean Silva #include "mlir/Pass/Pass.h"
189ed1e587SSean Silva #include "mlir/Pass/PassRegistry.h"
19b6eb26fdSRiver Riddle #include "mlir/Transforms/GreedyPatternRewriteDriver.h"
209ed1e587SSean Silva
219ed1e587SSean Silva using namespace mlir;
229ed1e587SSean Silva namespace {
233842d4b6STres Popp #include "ShapeToStandard.cpp.inc"
249ed1e587SSean Silva } // namespace
259ed1e587SSean Silva
269ed1e587SSean Silva namespace {
279ed1e587SSean Silva class ConvertCstrRequireOp : public OpRewritePattern<shape::CstrRequireOp> {
289ed1e587SSean Silva public:
299ed1e587SSean Silva using OpRewritePattern::OpRewritePattern;
matchAndRewrite(shape::CstrRequireOp op,PatternRewriter & rewriter) const309ed1e587SSean Silva LogicalResult matchAndRewrite(shape::CstrRequireOp op,
319ed1e587SSean Silva PatternRewriter &rewriter) const override {
32ace01605SRiver Riddle rewriter.create<cf::AssertOp>(op.getLoc(), op.getPred(), op.getMsgAttr());
339ed1e587SSean Silva rewriter.replaceOpWithNewOp<shape::ConstWitnessOp>(op, true);
349ed1e587SSean Silva return success();
359ed1e587SSean Silva }
369ed1e587SSean Silva };
379ed1e587SSean Silva } // namespace
389ed1e587SSean Silva
populateConvertShapeConstraintsConversionPatterns(RewritePatternSet & patterns)399ed1e587SSean Silva void mlir::populateConvertShapeConstraintsConversionPatterns(
40dc4e913bSChris Lattner RewritePatternSet &patterns) {
41dc4e913bSChris Lattner patterns.add<CstrBroadcastableToRequire>(patterns.getContext());
42dc4e913bSChris Lattner patterns.add<CstrEqToRequire>(patterns.getContext());
43dc4e913bSChris Lattner patterns.add<ConvertCstrRequireOp>(patterns.getContext());
449ed1e587SSean Silva }
459ed1e587SSean Silva
469ed1e587SSean Silva namespace {
479ed1e587SSean Silva // This pass eliminates shape constraints from the program, converting them to
489ed1e587SSean Silva // eager (side-effecting) error handling code. After eager error handling code
499ed1e587SSean Silva // is emitted, witnesses are satisfied, so they are replace with
509ed1e587SSean Silva // `shape.const_witness true`.
519ed1e587SSean Silva class ConvertShapeConstraints
529ed1e587SSean Silva : public ConvertShapeConstraintsBase<ConvertShapeConstraints> {
runOnOperation()532d128b04SRahul Joshi void runOnOperation() override {
54ceefc261SMehdi Amini auto *func = getOperation();
559ed1e587SSean Silva auto *context = &getContext();
569ed1e587SSean Silva
57dc4e913bSChris Lattner RewritePatternSet patterns(context);
583a506b31SChris Lattner populateConvertShapeConstraintsConversionPatterns(patterns);
599ed1e587SSean Silva
60b6eb26fdSRiver Riddle if (failed(applyPatternsAndFoldGreedily(func, std::move(patterns))))
619ed1e587SSean Silva return signalPassFailure();
629ed1e587SSean Silva }
639ed1e587SSean Silva };
649ed1e587SSean Silva } // namespace
659ed1e587SSean Silva
createConvertShapeConstraintsPass()6647f175b0SRiver Riddle std::unique_ptr<Pass> mlir::createConvertShapeConstraintsPass() {
679ed1e587SSean Silva return std::make_unique<ConvertShapeConstraints>();
689ed1e587SSean Silva }
69