blob: 01f484c2e8e23232689e99a05dd911507e3046d9 [file] [log] [blame]
// Copyright 2019 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// https://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#ifndef IREE_COMPILER_TRANSFORMS_CONVERSIONUTILS_H_
#define IREE_COMPILER_TRANSFORMS_CONVERSIONUTILS_H_
#include "compiler/Utils/MemRefUtils.h"
#include "compiler/Utils/TypeConversionUtils.h"
#include "mlir/Transforms/DialectConversion.h"
namespace mlir {
namespace iree_compiler {
template <typename SrcOp, typename DstOp>
struct UnaryOpLowering : public OpConversionPattern<SrcOp> {
using OpConversionPattern<SrcOp>::OpConversionPattern;
PatternMatchResult matchAndRewrite(
SrcOp op, ArrayRef<Value *> operands,
ConversionPatternRewriter &rewriter) const override {
auto *value = loadAccessValue(op.getLoc(), operands[0], rewriter);
value = wrapAsMemRef(value, op, rewriter);
auto dstType = convertTypeToMemRef(op.getResult());
auto dstOp = rewriter.create<DstOp>(op.getLoc(), dstType, value);
auto result = dstOp.getResult();
result = wrapAsTensor(result, op, rewriter);
rewriter.replaceOp(
op, {loadResultValue(op.getLoc(), op.getType(), result, rewriter)});
return this->matchSuccess();
}
};
template <typename SrcOp, typename DstOp>
struct BinaryOpLowering : public OpConversionPattern<SrcOp> {
using OpConversionPattern<SrcOp>::OpConversionPattern;
PatternMatchResult matchAndRewrite(
SrcOp op, ArrayRef<Value *> operands,
ConversionPatternRewriter &rewriter) const override {
auto *lhsValue = loadAccessValue(op.getLoc(), operands[0], rewriter);
auto *rhsValue = loadAccessValue(op.getLoc(), operands[1], rewriter);
auto dstType = convertTypeToMemRef(op.getResult());
lhsValue = wrapAsMemRef(lhsValue, op, rewriter);
rhsValue = wrapAsMemRef(rhsValue, op, rewriter);
auto midOp =
rewriter.create<DstOp>(op.getLoc(), dstType, lhsValue, rhsValue);
auto result = midOp.getResult();
result = wrapAsTensor(result, op, rewriter);
rewriter.replaceOp(
op, {loadResultValue(op.getLoc(), op.getType(), result, rewriter)});
return this->matchSuccess();
}
};
template <typename SrcOp, typename DstOp>
struct TernaryOpLowering : public OpConversionPattern<SrcOp> {
using OpConversionPattern<SrcOp>::OpConversionPattern;
PatternMatchResult matchAndRewrite(
SrcOp op, ArrayRef<Value *> operands,
ConversionPatternRewriter &rewriter) const override {
auto *aValue = loadAccessValue(op.getLoc(), operands[0], rewriter);
auto *bValue = loadAccessValue(op.getLoc(), operands[1], rewriter);
auto *cValue = loadAccessValue(op.getLoc(), operands[2], rewriter);
aValue = wrapAsMemRef(aValue, op, rewriter);
bValue = wrapAsMemRef(bValue, op, rewriter);
cValue = wrapAsMemRef(cValue, op, rewriter);
auto dstType = convertTypeToMemRef(op.getResult());
auto dstOp =
rewriter.create<DstOp>(op.getLoc(), dstType, aValue, bValue, cValue);
auto result = dstOp.getResult();
result = wrapAsTensor(result, op, rewriter);
rewriter.replaceOp(
op, {loadResultValue(op.getLoc(), op.getType(), result, rewriter)});
return this->matchSuccess();
}
};
} // namespace iree_compiler
} // namespace mlir
#endif // IREE_COMPILER_TRANSFORMS_CONVERSIONUTILS_H_