//===- Bufferize.cpp - Bufferization for Arith ops ---------*- C++ -*-===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// #include "mlir/Dialect/Arith/Transforms/Passes.h" #include "mlir/Dialect/Arith/IR/Arith.h" #include "mlir/Dialect/Arith/Transforms/BufferizableOpInterfaceImpl.h" #include "mlir/Dialect/Bufferization/IR/BufferizableOpInterface.h" #include "mlir/Dialect/Bufferization/IR/Bufferization.h" #include "mlir/Dialect/Bufferization/Transforms/Bufferize.h" #include "mlir/Dialect/MemRef/IR/MemRef.h" namespace mlir { namespace arith { #define GEN_PASS_DEF_ARITHBUFFERIZEPASS #include "mlir/Dialect/Arith/Transforms/Passes.h.inc" } // namespace arith } // namespace mlir using namespace mlir; using namespace bufferization; namespace { /// Pass to bufferize Arith ops. struct ArithBufferizePass : public arith::impl::ArithBufferizePassBase { using ArithBufferizePassBase::ArithBufferizePassBase; ArithBufferizePass(uint64_t alignment = 0, bool constantOpOnly = false) : constantOpOnly(constantOpOnly) { this->alignment = alignment; } void runOnOperation() override { BufferizationOptions options = getPartialBufferizationOptions(); if (constantOpOnly) { options.opFilter.allowOperation(); } else { options.opFilter.allowDialect(); } options.bufferAlignment = alignment; if (failed(bufferizeOp(getOperation(), options))) signalPassFailure(); } void getDependentDialects(DialectRegistry ®istry) const override { registry.insert(); arith::registerBufferizableOpInterfaceExternalModels(registry); } private: bool constantOpOnly; }; } // namespace std::unique_ptr mlir::arith::createConstantBufferizePass(uint64_t alignment) { return std::make_unique(alignment, /*constantOpOnly=*/true); }