[RISCV] Add Qualcomm uC Xqcics(Conditional Select) extension (#119504)
[llvm-project.git] / mlir / test / Conversion / TosaToLinalg / tosa-to-linalg-invalid.mlir
blobea1b79cbd9507f8c70e5f141a2170ab0244c6d1a
1 // RUN: mlir-opt --split-input-file -pass-pipeline="builtin.module(func.func(tosa-to-linalg))" %s -verify-diagnostics
3 // CHECK-LABEL: @avg_pool2d_with_unsupported_quant_type
4 func.func @avg_pool2d_with_unsupported_quant_type(%arg0: tensor<1x7x7x9x!quant.uniform<i8:f32, 0.01>>) -> tensor<1x7x7x9x!quant.uniform<i8:f32, 0.01>> {
5   // expected-error@+1 {{failed to legalize operation 'tosa.avg_pool2d'}}
6   %0 = "tosa.avg_pool2d"(%arg0) {acc_type = i32, kernel = array<i64: 2, 2>, pad = array<i64: 0, 1, 0, 1>, stride = array<i64: 1, 1>} : (tensor<1x7x7x9x!quant.uniform<i8:f32, 0.01>>) -> tensor<1x7x7x9x!quant.uniform<i8:f32, 0.01>>
7   return %0 : tensor<1x7x7x9x!quant.uniform<i8:f32, 0.01>>
10 // -----
12 // CHECK-LABEL: @tensor_with_unknown_rank
13 func.func @tensor_with_unknown_rank(%arg0: tensor<*xi8>) -> tensor<*xi8> {
14   // expected-error@+1 {{failed to legalize operation 'tosa.abs'}}
15   %0 = "tosa.abs"(%arg0) : (tensor<*xi8>) -> tensor<*xi8>
16   return %0 : tensor<*xi8>
19 // -----
21 // CHECK-LABEL: @unranked_add
22 func.func @unranked_add(%arg0 : tensor<10x10xf32> , %arg1 : tensor<10x10xf32>, %arg2 : tensor<*xf32>) -> (tensor<10x10xf32>) {
23   // expected-error@+3 {{failed to legalize operation 'tosa.add'}}
24   %reduce = tosa.reduce_max %arg0 {axis = 1 : i32} : (tensor<10x10xf32>) -> tensor<10x1xf32>
25   %1 = tosa.add %reduce, %arg1 : (tensor<10x1xf32>, tensor<10x10xf32>) -> tensor<10x10xf32>
26   %0 = tosa.add %1, %arg2 : (tensor<10x10xf32>, tensor<*xf32>) -> tensor<*xf32>
27   %2 = tosa.reshape %0 {new_shape = array<i64: 10, 10>} : (tensor<*xf32>) -> tensor<10x10xf32>
28   return %2 : tensor<10x10xf32>
31 // -----
33 // CHECK-LABEL: @rfft2d_with_non_float_type
34 func.func @rfft2d_with_non_float_type(%arg0 : tensor<1x1x1xi32>) -> (tensor<1x1x1xi32>, tensor<1x1x1xi32>) {
35   // expected-error@+1 {{failed to legalize operation 'tosa.rfft2d'}}
36   %real, %imag = tosa.rfft2d %arg0 : (tensor<1x1x1xi32>) -> (tensor<1x1x1xi32>, tensor<1x1x1xi32>)
37   return %real, %imag : tensor<1x1x1xi32>, tensor<1x1x1xi32>
40 // -----
42 // CHECK-LABEL: @rescale_unsupported_type
43 func.func @rescale_unsupported_type(%arg0: tensor<13x21x3x!quant.uniform<u8:f32, 0.015655439347028732:127>>) -> tensor<13x21x3x!quant.uniform<i8:f32, 0.015655439347028732:-1>> {
44   // expected-error@+1 {{failed to legalize operation 'tosa.rescale'}}
45   %0 = tosa.rescale %arg0 {double_round = false, input_zp = 127 : i32, multiplier = array<i32: 1073741824>, output_zp = -1 : i32, per_channel = false, scale32 = true, shift = array<i8: 30>} : (tensor<13x21x3x!quant.uniform<u8:f32, 0.015655439347028732:127>>) -> tensor<13x21x3x!quant.uniform<i8:f32, 0.015655439347028732:-1>>
46   return %0 : tensor<13x21x3x!quant.uniform<i8:f32, 0.015655439347028732:-1>>