forked from OSchip/llvm-project
[mlir][linalg] Propagate attributes when doing named ops conversion.
Custom attributes can be set on the operation. It prevents them to be removed when doing named ops conversion. Reviewed By: mravishankar Differential Revision: https://reviews.llvm.org/D133892
This commit is contained in:
parent
b2c195da6d
commit
e07d749e7d
|
@ -14,6 +14,7 @@
|
||||||
#include "mlir/Dialect/SCF/IR/SCF.h"
|
#include "mlir/Dialect/SCF/IR/SCF.h"
|
||||||
#include "llvm/ADT/MapVector.h"
|
#include "llvm/ADT/MapVector.h"
|
||||||
#include "llvm/ADT/SetVector.h"
|
#include "llvm/ADT/SetVector.h"
|
||||||
|
#include "llvm/ADT/StringSet.h"
|
||||||
|
|
||||||
namespace mlir {
|
namespace mlir {
|
||||||
class AffineExpr;
|
class AffineExpr;
|
||||||
|
@ -495,6 +496,23 @@ struct GenerateLoopNest {
|
||||||
ArrayRef<linalg::ProcInfo> procInfo = {});
|
ArrayRef<linalg::ProcInfo> procInfo = {});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/// Returns an attribute list that excludes pre-defined attributes.
|
||||||
|
template <typename OpTy>
|
||||||
|
SmallVector<NamedAttribute> getPrunedAttributeList(OpTy op) {
|
||||||
|
llvm::StringSet<> elidedAttrs;
|
||||||
|
elidedAttrs.insert(op.getAttributeNames().begin(),
|
||||||
|
op.getAttributeNames().end());
|
||||||
|
if (isa<linalg::LinalgOp>(op.getOperation()))
|
||||||
|
elidedAttrs.insert(LinalgDialect::kMemoizedIndexingMapsAttrName);
|
||||||
|
SmallVector<NamedAttribute> attrs;
|
||||||
|
for (auto attr : op->getAttrs()) {
|
||||||
|
if (elidedAttrs.count(attr.getName()))
|
||||||
|
continue;
|
||||||
|
attrs.push_back(attr);
|
||||||
|
}
|
||||||
|
return attrs;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace linalg
|
} // namespace linalg
|
||||||
} // namespace mlir
|
} // namespace mlir
|
||||||
|
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
#include "mlir/IR/PatternMatch.h"
|
#include "mlir/IR/PatternMatch.h"
|
||||||
#include "mlir/Transforms/GreedyPatternRewriteDriver.h"
|
#include "mlir/Transforms/GreedyPatternRewriteDriver.h"
|
||||||
#include "llvm/ADT/SmallVector.h"
|
#include "llvm/ADT/SmallVector.h"
|
||||||
|
#include "llvm/ADT/TypeSwitch.h"
|
||||||
|
|
||||||
namespace mlir {
|
namespace mlir {
|
||||||
#define GEN_PASS_DEF_LINALGNAMEDOPCONVERSION
|
#define GEN_PASS_DEF_LINALGNAMEDOPCONVERSION
|
||||||
|
@ -72,28 +73,30 @@ matchAndReplaceDepthwiseConv(Operation *operation, Value input, Value kernel,
|
||||||
auto collapsedInit = rewriter.create<tensor::CollapseShapeOp>(
|
auto collapsedInit = rewriter.create<tensor::CollapseShapeOp>(
|
||||||
loc, newInitTy, init, collapsedInitDims);
|
loc, newInitTy, init, collapsedInitDims);
|
||||||
|
|
||||||
Value newConv;
|
SmallVector<NamedAttribute> preservedAttrs;
|
||||||
if (isa<DepthwiseConv2DNhwcHwcmOp>(operation)) {
|
Operation *newConv =
|
||||||
newConv = rewriter
|
TypeSwitch<Operation *, Operation *>(operation)
|
||||||
.create<DepthwiseConv2DNhwcHwcOp>(
|
.Case<DepthwiseConv2DNhwcHwcmOp>([&](auto op) {
|
||||||
loc, newInitTy, ValueRange{input, collapsedKernel},
|
preservedAttrs = getPrunedAttributeList(op);
|
||||||
ValueRange{collapsedInit}, stride, dilation)
|
return rewriter.create<DepthwiseConv2DNhwcHwcOp>(
|
||||||
.getResult(0);
|
loc, newInitTy, ValueRange{input, collapsedKernel},
|
||||||
} else if (isa<DepthwiseConv2DNhwcHwcmQOp>(operation)) {
|
ValueRange{collapsedInit}, stride, dilation);
|
||||||
newConv =
|
})
|
||||||
rewriter
|
.Case<DepthwiseConv2DNhwcHwcmQOp>([&](auto op) {
|
||||||
.create<DepthwiseConv2DNhwcHwcQOp>(
|
preservedAttrs = getPrunedAttributeList(op);
|
||||||
|
return rewriter.create<DepthwiseConv2DNhwcHwcQOp>(
|
||||||
loc, newInitTy, ValueRange{input, collapsedKernel, iZp, kZp},
|
loc, newInitTy, ValueRange{input, collapsedKernel, iZp, kZp},
|
||||||
ValueRange{collapsedInit}, stride, dilation)
|
ValueRange{collapsedInit}, stride, dilation);
|
||||||
.getResult(0);
|
})
|
||||||
}
|
.Default([](Operation *op) { return nullptr; });
|
||||||
|
|
||||||
if (!newConv)
|
if (!newConv)
|
||||||
return failure();
|
return failure();
|
||||||
|
for (auto attr : preservedAttrs)
|
||||||
|
newConv->setAttr(attr.getName(), attr.getValue());
|
||||||
|
|
||||||
// Expand dimensions back out to
|
// Expand dimensions back out to
|
||||||
rewriter.replaceOpWithNewOp<tensor::ExpandShapeOp>(
|
rewriter.replaceOpWithNewOp<tensor::ExpandShapeOp>(
|
||||||
operation, resultTy, newConv, collapsedInitDims);
|
operation, resultTy, newConv->getResult(0), collapsedInitDims);
|
||||||
return success();
|
return success();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -4,9 +4,9 @@
|
||||||
func.func @depthwise_conv(%arg0: tensor<?x?x?x?xf32>, %arg1: tensor<?x?x?x1xf32>, %arg2: tensor<?x?x?x?x1xf32>) -> tensor<?x?x?x?x1xf32> {
|
func.func @depthwise_conv(%arg0: tensor<?x?x?x?xf32>, %arg1: tensor<?x?x?x1xf32>, %arg2: tensor<?x?x?x?x1xf32>) -> tensor<?x?x?x?x1xf32> {
|
||||||
// CHECK-DAG: %[[KERNEL:.+]] = tensor.collapse_shape %arg1 {{\[\[}}0], [1], [2, 3]]
|
// CHECK-DAG: %[[KERNEL:.+]] = tensor.collapse_shape %arg1 {{\[\[}}0], [1], [2, 3]]
|
||||||
// CHECK-DAG: %[[INIT:.+]] = tensor.collapse_shape %arg2 {{\[\[}}0], [1], [2], [3, 4]]
|
// CHECK-DAG: %[[INIT:.+]] = tensor.collapse_shape %arg2 {{\[\[}}0], [1], [2], [3, 4]]
|
||||||
// CHECK-DAG: %[[CONV:.+]] = linalg.depthwise_conv_2d_nhwc_hwc {dilations = dense<1> : tensor<2xi64>, strides = dense<2> : tensor<2xi64>} ins(%arg0, %[[KERNEL]] : tensor<?x?x?x?xf32>, tensor<?x?x?xf32>) outs(%[[INIT]] : tensor<?x?x?x?xf32>)
|
// CHECK-DAG: %[[CONV:.+]] = linalg.depthwise_conv_2d_nhwc_hwc {_someattr, dilations = dense<1> : tensor<2xi64>, strides = dense<2> : tensor<2xi64>} ins(%arg0, %[[KERNEL]] : tensor<?x?x?x?xf32>, tensor<?x?x?xf32>) outs(%[[INIT]] : tensor<?x?x?x?xf32>)
|
||||||
// CHECK: %[[OUT:.+]] = tensor.expand_shape %[[CONV]] {{\[\[}}0], [1], [2], [3, 4]]
|
// CHECK: %[[OUT:.+]] = tensor.expand_shape %[[CONV]] {{\[\[}}0], [1], [2], [3, 4]]
|
||||||
%0 = linalg.depthwise_conv_2d_nhwc_hwcm {dilations = dense<1> : tensor<2xi64>, strides = dense<2> : tensor<2xi64>} ins(%arg0, %arg1 : tensor<?x?x?x?xf32>, tensor<?x?x?x1xf32>) outs(%arg2 : tensor<?x?x?x?x1xf32>) -> tensor<?x?x?x?x1xf32>
|
%0 = linalg.depthwise_conv_2d_nhwc_hwcm {_someattr, dilations = dense<1> : tensor<2xi64>, strides = dense<2> : tensor<2xi64>} ins(%arg0, %arg1 : tensor<?x?x?x?xf32>, tensor<?x?x?x1xf32>) outs(%arg2 : tensor<?x?x?x?x1xf32>) -> tensor<?x?x?x?x1xf32>
|
||||||
return %0 : tensor<?x?x?x?x1xf32>
|
return %0 : tensor<?x?x?x?x1xf32>
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,8 +17,8 @@ func.func @depthwise_conv(%arg0: tensor<?x?x?x?xf32>, %arg1: tensor<?x?x?x1xf32>
|
||||||
func.func @depthwise_conv_q(%arg0: tensor<?x?x?x?xi8>, %arg1: tensor<?x?x?x1xi8>, %arg2: tensor<?x?x?x?x1xi32>, %arg3 : i32, %arg4 : i32) -> tensor<?x?x?x?x1xi32> {
|
func.func @depthwise_conv_q(%arg0: tensor<?x?x?x?xi8>, %arg1: tensor<?x?x?x1xi8>, %arg2: tensor<?x?x?x?x1xi32>, %arg3 : i32, %arg4 : i32) -> tensor<?x?x?x?x1xi32> {
|
||||||
// CHECK-DAG: %[[KERNEL:.+]] = tensor.collapse_shape %arg1 {{\[\[}}0], [1], [2, 3]]
|
// CHECK-DAG: %[[KERNEL:.+]] = tensor.collapse_shape %arg1 {{\[\[}}0], [1], [2, 3]]
|
||||||
// CHECK-DAG: %[[INIT:.+]] = tensor.collapse_shape %arg2 {{\[\[}}0], [1], [2], [3, 4]]
|
// CHECK-DAG: %[[INIT:.+]] = tensor.collapse_shape %arg2 {{\[\[}}0], [1], [2], [3, 4]]
|
||||||
// CHECK-DAG: %[[CONV:.+]] = linalg.depthwise_conv_2d_nhwc_hwc_q {dilations = dense<1> : tensor<2xi64>, strides = dense<2> : tensor<2xi64>} ins(%arg0, %[[KERNEL]], %arg3, %arg4 : tensor<?x?x?x?xi8>, tensor<?x?x?xi8>, i32, i32) outs(%[[INIT]] : tensor<?x?x?x?xi32>)
|
// CHECK-DAG: %[[CONV:.+]] = linalg.depthwise_conv_2d_nhwc_hwc_q {_someattr, dilations = dense<1> : tensor<2xi64>, strides = dense<2> : tensor<2xi64>} ins(%arg0, %[[KERNEL]], %arg3, %arg4 : tensor<?x?x?x?xi8>, tensor<?x?x?xi8>, i32, i32) outs(%[[INIT]] : tensor<?x?x?x?xi32>)
|
||||||
// CHECK: %[[OUT:.+]] = tensor.expand_shape %[[CONV]] {{\[\[}}0], [1], [2], [3, 4]]
|
// CHECK: %[[OUT:.+]] = tensor.expand_shape %[[CONV]] {{\[\[}}0], [1], [2], [3, 4]]
|
||||||
%0 = linalg.depthwise_conv_2d_nhwc_hwcm_q {dilations = dense<1> : tensor<2xi64>, strides = dense<2> : tensor<2xi64>} ins(%arg0, %arg1, %arg3, %arg4 : tensor<?x?x?x?xi8>, tensor<?x?x?x1xi8>, i32, i32) outs(%arg2 : tensor<?x?x?x?x1xi32>) -> tensor<?x?x?x?x1xi32>
|
%0 = linalg.depthwise_conv_2d_nhwc_hwcm_q {_someattr, dilations = dense<1> : tensor<2xi64>, strides = dense<2> : tensor<2xi64>} ins(%arg0, %arg1, %arg3, %arg4 : tensor<?x?x?x?xi8>, tensor<?x?x?x1xi8>, i32, i32) outs(%arg2 : tensor<?x?x?x?x1xi32>) -> tensor<?x?x?x?x1xi32>
|
||||||
return %0 : tensor<?x?x?x?x1xi32>
|
return %0 : tensor<?x?x?x?x1xi32>
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue