2020-10-13 03:23:45 +08:00
|
|
|
// RUN: mlir-opt -split-input-file -shape-bufferize <%s | FileCheck %s
|
2020-09-22 18:23:43 +08:00
|
|
|
|
|
|
|
// -----
|
2020-10-20 06:59:03 +08:00
|
|
|
|
|
|
|
// CHECK-LABEL: func @shape_assuming() {
|
|
|
|
// CHECK: %[[WTRUE:.*]] = shape.const_witness true
|
|
|
|
// CHECK: %[[MEMREF:.*]] = shape.assuming %[[WTRUE]] -> (memref<2xf16>) {
|
|
|
|
// CHECK: %[[TENSOR_VAL:.*]] = "test.source"() : () -> tensor<2xf16>
|
2021-02-10 20:53:11 +08:00
|
|
|
// CHECK: %[[YIELDED_MEMREF:.*]] = memref.buffer_cast %[[TENSOR_VAL]] : memref<2xf16>
|
2020-10-20 06:59:03 +08:00
|
|
|
// CHECK: shape.assuming_yield %[[YIELDED_MEMREF]] : memref<2xf16>
|
|
|
|
// CHECK: }
|
2021-02-10 20:53:11 +08:00
|
|
|
// CHECK: %[[TENSOR:.*]] = memref.tensor_load %[[MEMREF:.*]] : memref<2xf16>
|
2020-10-20 06:59:03 +08:00
|
|
|
// CHECK: "test.sink"(%[[TENSOR]]) : (tensor<2xf16>) -> ()
|
|
|
|
// CHECK: return
|
|
|
|
// CHECK: }
|
|
|
|
func @shape_assuming() {
|
2020-09-22 18:23:43 +08:00
|
|
|
%0 = shape.const_witness true
|
|
|
|
%1 = shape.assuming %0 -> (tensor<2xf16>) {
|
|
|
|
%2 = "test.source"() : () -> (tensor<2xf16>)
|
|
|
|
shape.assuming_yield %2 : tensor<2xf16>
|
|
|
|
}
|
|
|
|
"test.sink"(%1) : (tensor<2xf16>) -> ()
|
|
|
|
return
|
|
|
|
}
|