xref: /llvm-project/mlir/test/Dialect/Bufferization/Transforms/tensor-copy-insertion-memory-space.mlir (revision 6bf043e7433680c6f4e36393734ef83699b30f14)
1c1fef4e8SMatthias Springer// RUN: mlir-opt %s -test-tensor-copy-insertion="must-infer-memory-space" -split-input-file | FileCheck %s
2c0b0b6a0SMatthias Springer
3c0b0b6a0SMatthias Springer// CHECK-LABEL: func @unknown_op_copy
4c0b0b6a0SMatthias Springerfunc.func @unknown_op_copy() -> (tensor<10xf32>, tensor<10xf32>) {
5c0b0b6a0SMatthias Springer  %c0 = arith.constant 0 : index
6c0b0b6a0SMatthias Springer  %cst = arith.constant 0.0 : f32
7c0b0b6a0SMatthias Springer  // CHECK: %[[dummy:.*]] = "test.dummy_op"() : () -> tensor<10xf32>
8c0b0b6a0SMatthias Springer  %t = "test.dummy_op"() : () -> tensor<10xf32>
9*6bf043e7SMartin Erhart  // CHECK: %[[copy:.*]] = bufferization.alloc_tensor() copy(%[[dummy]]) : tensor<10xf32>
10c0b0b6a0SMatthias Springer  %s = tensor.insert %cst into %t[%c0] : tensor<10xf32>
11c0b0b6a0SMatthias Springer  return %s, %t : tensor<10xf32>, tensor<10xf32>
12c0b0b6a0SMatthias Springer}
13c0b0b6a0SMatthias Springer
14c0b0b6a0SMatthias Springer// -----
15c0b0b6a0SMatthias Springer
16c0b0b6a0SMatthias Springer// CHECK-LABEL: func @alloc_tensor_copy
17c0b0b6a0SMatthias Springerfunc.func @alloc_tensor_copy() -> (tensor<10xf32>, tensor<10xf32>) {
18c0b0b6a0SMatthias Springer  %c0 = arith.constant 0 : index
19c0b0b6a0SMatthias Springer  %cst = arith.constant 0.0 : f32
20*6bf043e7SMartin Erhart  // CHECK: bufferization.alloc_tensor() {memory_space = 1 : ui64} : tensor<10xf32>
21c0b0b6a0SMatthias Springer  %t = bufferization.alloc_tensor() {memory_space = 1 : ui64} : tensor<10xf32>
22*6bf043e7SMartin Erhart  // CHECK: bufferization.alloc_tensor() {memory_space = 1 : ui64} : tensor<10xf32>
23c0b0b6a0SMatthias Springer  %s = tensor.insert %cst into %t[%c0] : tensor<10xf32>
24c0b0b6a0SMatthias Springer  return %s, %t : tensor<10xf32>, tensor<10xf32>
25c0b0b6a0SMatthias Springer}
26