diff --git a/mlir/lib/Conversion/TosaToLinalg/TosaToLinalgNamed.cpp b/mlir/lib/Conversion/TosaToLinalg/TosaToLinalgNamed.cpp --- a/mlir/lib/Conversion/TosaToLinalg/TosaToLinalgNamed.cpp +++ b/mlir/lib/Conversion/TosaToLinalg/TosaToLinalgNamed.cpp @@ -766,6 +766,9 @@ llvm::append_range(pad, op.getPad()); pad.resize(pad.size() + 2, 0); TypedAttr padAttr = rewriter.getZeroAttr(inElementTy); + // Unsupported element type + if (!padAttr) + return failure(); Value paddedInput = applyPad(loc, input, pad, padAttr, rewriter); auto initialAttr = rewriter.getZeroAttr(accETy); diff --git a/mlir/test/Conversion/TosaToLinalg/unsupported-conversion.mlir b/mlir/test/Conversion/TosaToLinalg/unsupported-conversion.mlir new file mode 100644 --- /dev/null +++ b/mlir/test/Conversion/TosaToLinalg/unsupported-conversion.mlir @@ -0,0 +1,8 @@ +// RUN: mlir-opt --split-input-file -pass-pipeline="builtin.module(func.func(tosa-to-linalg-named))" %s -verify-diagnostics + +// CHECK-LABEL: @avg_pool2d_with_unsupported_quant_type +func.func @avg_pool2d_with_unsupported_quant_type(%arg0: tensor<1x7x7x9x!quant.uniform>) -> tensor<1x7x7x9x!quant.uniform> { + // expected-error@+1 {{failed to legalize operation 'tosa.avg_pool2d'}} + %0 = "tosa.avg_pool2d"(%arg0) {acc_type = i32, kernel = array, pad = array, stride = array} : (tensor<1x7x7x9x!quant.uniform>) -> tensor<1x7x7x9x!quant.uniform> + return %0 : tensor<1x7x7x9x!quant.uniform> +}