//===- EmulateWideInt.cpp - Wide integer operation emulation ----*- 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/IR/Arith.h" #include "mlir/Dialect/Arith/Transforms/Passes.h" #include "mlir/Dialect/Arith/Transforms/WideIntEmulationConverter.h" #include "mlir/Dialect/MemRef/IR/MemRef.h" #include "mlir/Dialect/MemRef/Transforms/Passes.h" #include "mlir/Dialect/MemRef/Transforms/Transforms.h" #include "mlir/Dialect/Vector/IR/VectorOps.h" #include "mlir/Transforms/DialectConversion.h" #include "llvm/Support/FormatVariadic.h" #include "llvm/Support/MathExtras.h" #include <cassert> namespace mlir::memref { #define GEN_PASS_DEF_MEMREFEMULATEWIDEINT #include "mlir/Dialect/MemRef/Transforms/Passes.h.inc" } // namespace mlir::memref usingnamespacemlir; namespace { //===----------------------------------------------------------------------===// // ConvertMemRefAlloc //===----------------------------------------------------------------------===// struct ConvertMemRefAlloc final : OpConversionPattern<memref::AllocOp> { … }; //===----------------------------------------------------------------------===// // ConvertMemRefLoad //===----------------------------------------------------------------------===// struct ConvertMemRefLoad final : OpConversionPattern<memref::LoadOp> { … }; //===----------------------------------------------------------------------===// // ConvertMemRefStore //===----------------------------------------------------------------------===// struct ConvertMemRefStore final : OpConversionPattern<memref::StoreOp> { … }; //===----------------------------------------------------------------------===// // Pass Definition //===----------------------------------------------------------------------===// struct EmulateWideIntPass final : memref::impl::MemRefEmulateWideIntBase<EmulateWideIntPass> { … }; } // end anonymous namespace //===----------------------------------------------------------------------===// // Public Interface Definition //===----------------------------------------------------------------------===// void memref::populateMemRefWideIntEmulationPatterns( arith::WideIntEmulationConverter &typeConverter, RewritePatternSet &patterns) { … } void memref::populateMemRefWideIntEmulationConversions( arith::WideIntEmulationConverter &typeConverter) { … }