1
1
// RUN: mlir-opt -buffer-results-to-out-params -split-input-file -verify-diagnostics %s | FileCheck %s
2
2
3
- // CHECK-LABEL: func @basic(
3
+ // CHECK-LABEL: func private @basic(
4
4
// CHECK-SAME: %[[ARG:.*]]: memref<f32>) {
5
5
// CHECK: %[[RESULT:.*]] = "test.source"() : () -> memref<f32>
6
6
// CHECK: memref.copy %[[RESULT]], %[[ARG]] : memref<f32> to memref<f32>
7
7
// CHECK: return
8
8
// CHECK: }
9
- func.func @basic () -> (memref <f32 >) {
9
+ func.func private @basic () -> (memref <f32 >) {
10
10
%0 = " test.source" () : () -> (memref <f32 >)
11
11
return %0 : memref <f32 >
12
12
}
13
13
14
- // CHECK-LABEL: func @presence_of_existing_arguments(
14
+ // CHECK-LABEL: func private @presence_of_existing_arguments(
15
15
// CHECK-SAME: %[[ARG0:.*]]: memref<1xf32>,
16
16
// CHECK-SAME: %[[ARG1:.*]]: memref<2xf32>) {
17
17
// CHECK: %[[RESULT:.*]] = "test.source"() : () -> memref<2xf32>
18
18
// CHECK: memref.copy %[[RESULT]], %[[ARG1]] : memref<2xf32> to memref<2xf32>
19
19
// CHECK: return
20
20
// CHECK: }
21
- func.func @presence_of_existing_arguments (%arg0: memref <1 xf32 >) -> (memref <2 xf32 >) {
21
+ func.func private @presence_of_existing_arguments (%arg0: memref <1 xf32 >) -> (memref <2 xf32 >) {
22
22
%0 = " test.source" () : () -> (memref <2 xf32 >)
23
23
return %0 : memref <2 xf32 >
24
24
}
25
25
26
- // CHECK-LABEL: func @multiple_results(
26
+ // CHECK-LABEL: func private @multiple_results(
27
27
// CHECK-SAME: %[[ARG0:.*]]: memref<1xf32>,
28
28
// CHECK-SAME: %[[ARG1:.*]]: memref<2xf32>) {
29
29
// CHECK: %[[RESULTS:.*]]:2 = "test.source"() : () -> (memref<1xf32>, memref<2xf32>)
30
30
// CHECK: memref.copy %[[RESULTS]]#0, %[[ARG0]] : memref<1xf32> to memref<1xf32>
31
31
// CHECK: memref.copy %[[RESULTS]]#1, %[[ARG1]] : memref<2xf32> to memref<2xf32>
32
32
// CHECK: return
33
33
// CHECK: }
34
- func.func @multiple_results () -> (memref <1 xf32 >, memref <2 xf32 >) {
34
+ func.func private @multiple_results () -> (memref <1 xf32 >, memref <2 xf32 >) {
35
35
%0 , %1 = " test.source" () : () -> (memref <1 xf32 >, memref <2 xf32 >)
36
36
return %0 , %1 : memref <1 xf32 >, memref <2 xf32 >
37
37
}
38
38
39
- // CHECK-LABEL: func @non_memref_types(
39
+ // CHECK-LABEL: func private @non_memref_types(
40
40
// CHECK-SAME: %[[OUTPARAM:.*]]: memref<f32>) -> (i1, i32) {
41
41
// CHECK: %[[RESULT1:.*]]:3 = "test.source"() : () -> (i1, memref<f32>, i32)
42
42
// CHECK: memref.copy %[[RESULT1]]#1, %[[OUTPARAM]] : memref<f32> to memref<f32>
43
43
// CHECK: return %[[RESULT1]]#0, %[[RESULT1]]#2 : i1, i32
44
44
// CHECK: }
45
- func.func @non_memref_types () -> (i1 , memref <f32 >, i32 ) {
45
+ func.func private @non_memref_types () -> (i1 , memref <f32 >, i32 ) {
46
46
%0 , %1 , %2 = " test.source" () : () -> (i1 , memref <f32 >, i32 )
47
47
return %0 , %1 , %2 : i1 , memref <f32 >, i32
48
48
}
49
49
50
- // CHECK: func private @external_function(memref<f32>)
50
+ // CHECK: func private @external_function() -> memref<f32>
51
51
func.func private @external_function () -> (memref <f32 >)
52
- // CHECK: func private @result_attrs(memref<f32> {test.some_attr})
52
+ // CHECK: func private @result_attrs() -> ( memref<f32> {test.some_attr})
53
53
func.func private @result_attrs () -> (memref <f32 > {test.some_attr })
54
- // CHECK: func private @mixed_result_attrs(memref<1xf32>, memref<2xf32> {test.some_attr}, memref<3xf32>)
54
+ // CHECK: func private @mixed_result_attrs() -> ( memref<1xf32>, memref<2xf32> {test.some_attr}, memref<3xf32>)
55
55
func.func private @mixed_result_attrs () -> (memref <1 xf32 >, memref <2 xf32 > {test.some_attr }, memref <3 xf32 >)
56
56
57
57
// -----
58
58
59
- // CHECK-LABEL: func private @callee(memref<1xf32>)
59
+ // CHECK-LABEL: func private @callee() -> memref<1xf32>
60
60
func.func private @callee () -> memref <1 xf32 >
61
61
62
62
// CHECK-LABEL: func @call_basic() {
63
- // CHECK: %[[OUTPARAM:.*]] = memref.alloc() : memref<1xf32>
64
- // CHECK: call @callee(%[[OUTPARAM]]) : (memref<1xf32>) -> ()
63
+ // CHECK: %[[OUTPARAM:.*]] = call @callee() : () -> memref<1xf32>
65
64
// CHECK: "test.sink"(%[[OUTPARAM]]) : (memref<1xf32>) -> ()
66
65
// CHECK: return
67
66
// CHECK: }
@@ -73,14 +72,12 @@ func.func @call_basic() {
73
72
74
73
// -----
75
74
76
- // CHECK-LABEL: func private @callee(memref<1xf32>, memref<2xf32>)
75
+ // CHECK-LABEL: func private @callee() -> ( memref<1xf32>, memref<2xf32>)
77
76
func.func private @callee () -> (memref <1 xf32 >, memref <2 xf32 >)
78
77
79
78
// CHECK-LABEL: func @call_multiple_result() {
80
- // CHECK: %[[RESULT0:.*]] = memref.alloc() : memref<1xf32>
81
- // CHECK: %[[RESULT1:.*]] = memref.alloc() : memref<2xf32>
82
- // CHECK: call @callee(%[[RESULT0]], %[[RESULT1]]) : (memref<1xf32>, memref<2xf32>) -> ()
83
- // CHECK: "test.sink"(%[[RESULT0]], %[[RESULT1]]) : (memref<1xf32>, memref<2xf32>) -> ()
79
+ // CHECK: %[[RESULTS:.*]]:2 = call @callee() : () -> (memref<1xf32>, memref<2xf32>)
80
+ // CHECK: "test.sink"(%[[RESULTS]]#0, %[[RESULTS]]#1) : (memref<1xf32>, memref<2xf32>) -> ()
84
81
// CHECK: }
85
82
func.func @call_multiple_result () {
86
83
%0 , %1 = call @callee () : () -> (memref <1 xf32 >, memref <2 xf32 >)
@@ -89,13 +86,12 @@ func.func @call_multiple_result() {
89
86
90
87
// -----
91
88
92
- // CHECK-LABEL: func private @callee(memref<1xf32> ) -> (i1, i32)
89
+ // CHECK-LABEL: func private @callee() -> (i1, memref<1xf32> , i32)
93
90
func.func private @callee () -> (i1 , memref <1 xf32 >, i32 )
94
91
95
92
// CHECK-LABEL: func @call_non_memref_result() {
96
- // CHECK: %[[RESULT0:.*]] = memref.alloc() : memref<1xf32>
97
- // CHECK: %[[NON_MEMREF_RESULTS:.*]]:2 = call @callee(%[[RESULT0]]) : (memref<1xf32>) -> (i1, i32)
98
- // CHECK: "test.sink"(%[[NON_MEMREF_RESULTS]]#0, %[[RESULT0]], %[[NON_MEMREF_RESULTS]]#1) : (i1, memref<1xf32>, i32) -> ()
93
+ // CHECK: %[[RESULTS:.*]]:3 = call @callee() : () -> (i1, memref<1xf32>, i32)
94
+ // CHECK: "test.sink"(%[[RESULTS]]#0, %[[RESULTS]]#1, %[[RESULTS]]#2) : (i1, memref<1xf32>, i32) -> ()
99
95
// CHECK: }
100
96
func.func @call_non_memref_result () {
101
97
%0 , %1 , %2 = call @callee () : () -> (i1 , memref <1 xf32 >, i32 )
@@ -104,10 +100,13 @@ func.func @call_non_memref_result() {
104
100
105
101
// -----
106
102
107
- func.func private @callee () -> (memref <?xf32 >)
103
+ func.func private @callee (%size: index ) -> (memref <?xf32 >) {
104
+ %alloc = memref.alloc (%size ) : memref <?xf32 >
105
+ return %alloc : memref <?xf32 >
106
+ }
108
107
109
- func.func @call_non_memref_result () {
108
+ func.func @call_non_memref_result (%size: index ) {
110
109
// expected-error @+1 {{cannot create out param for dynamically shaped result}}
111
- %0 = call @callee () : () -> (memref <?xf32 >)
110
+ %0 = call @callee (%size ) : (index ) -> (memref <?xf32 >)
112
111
" test.sink" (%0 ) : (memref <?xf32 >) -> ()
113
112
}
0 commit comments