|
1 |
| -// RUN: mlir-opt %s -test-unroll-vector-from-elements | FileCheck %s --check-prefix=CHECK-UNROLL |
| 1 | +// RUN: mlir-opt %s -transform-preload-library='transform-library-paths=%p/td/unroll-elements.mlir' \ |
| 2 | +// RUN: -transform-interpreter=entry-point=unroll_to_elements | FileCheck %s |
2 | 3 |
|
3 | 4 | //===----------------------------------------------------------------------===//
|
4 | 5 | // Test UnrollFromElements.
|
5 | 6 | //===----------------------------------------------------------------------===//
|
6 | 7 |
|
7 |
| -// CHECK-UNROLL-LABEL: @unroll_from_elements_2d |
8 |
| -// CHECK-UNROLL-SAME: (%[[ARG0:.*]]: f32, %[[ARG1:.*]]: f32, %[[ARG2:.*]]: f32, %[[ARG3:.*]]: f32) |
9 |
| -// CHECK-UNROLL-NEXT: %[[UNDEF_RES:.*]] = ub.poison : vector<2x2xf32> |
10 |
| -// CHECK-UNROLL-NEXT: %[[VEC_0:.*]] = vector.from_elements %[[ARG0]], %[[ARG1]] : vector<2xf32> |
11 |
| -// CHECK-UNROLL-NEXT: %[[RES_0:.*]] = vector.insert %[[VEC_0]], %[[UNDEF_RES]] [0] : vector<2xf32> into vector<2x2xf32> |
12 |
| -// CHECK-UNROLL-NEXT: %[[VEC_1:.*]] = vector.from_elements %[[ARG2]], %[[ARG3]] : vector<2xf32> |
13 |
| -// CHECK-UNROLL-NEXT: %[[RES_1:.*]] = vector.insert %[[VEC_1]], %[[RES_0]] [1] : vector<2xf32> into vector<2x2xf32> |
14 |
| -// CHECK-UNROLL-NEXT: return %[[RES_1]] : vector<2x2xf32> |
| 8 | +// CHECK-LABEL: @unroll_from_elements_2d |
| 9 | +// CHECK-SAME: (%[[ARG0:.*]]: f32, %[[ARG1:.*]]: f32, %[[ARG2:.*]]: f32, %[[ARG3:.*]]: f32) |
| 10 | +// CHECK-NEXT: %[[UNDEF_RES:.*]] = ub.poison : vector<2x2xf32> |
| 11 | +// CHECK-NEXT: %[[VEC_0:.*]] = vector.from_elements %[[ARG0]], %[[ARG1]] : vector<2xf32> |
| 12 | +// CHECK-NEXT: %[[RES_0:.*]] = vector.insert %[[VEC_0]], %[[UNDEF_RES]] [0] : vector<2xf32> into vector<2x2xf32> |
| 13 | +// CHECK-NEXT: %[[VEC_1:.*]] = vector.from_elements %[[ARG2]], %[[ARG3]] : vector<2xf32> |
| 14 | +// CHECK-NEXT: %[[RES_1:.*]] = vector.insert %[[VEC_1]], %[[RES_0]] [1] : vector<2xf32> into vector<2x2xf32> |
| 15 | +// CHECK-NEXT: return %[[RES_1]] : vector<2x2xf32> |
15 | 16 | func.func @unroll_from_elements_2d(%arg0: f32, %arg1: f32, %arg2: f32, %arg3: f32) -> vector<2x2xf32> {
|
16 | 17 | %0 = vector.from_elements %arg0, %arg1, %arg2, %arg3 : vector<2x2xf32>
|
17 | 18 | return %0 : vector<2x2xf32>
|
18 | 19 | }
|
19 | 20 |
|
20 |
| -// CHECK-UNROLL-LABEL: @unroll_from_elements_3d |
21 |
| -// CHECK-UNROLL-SAME: (%[[ARG0:.*]]: f32, %[[ARG1:.*]]: f32, %[[ARG2:.*]]: f32, %[[ARG3:.*]]: f32) |
22 |
| -// CHECK-UNROLL-NEXT: %[[UNDEF_RES:.*]] = ub.poison : vector<2x1x2xf32> |
23 |
| -// CHECK-UNROLL-NEXT: %[[UNDEF_RANK_2:.*]] = ub.poison : vector<1x2xf32> |
24 |
| -// CHECK-UNROLL-NEXT: %[[VEC_0:.*]] = vector.from_elements %[[ARG0]], %[[ARG1]] : vector<2xf32> |
25 |
| -// CHECK-UNROLL-NEXT: %[[RANK_2_0:.*]] = vector.insert %[[VEC_0]], %[[UNDEF_RANK_2]] [0] : vector<2xf32> into vector<1x2xf32> |
26 |
| -// CHECK-UNROLL-NEXT: %[[RES_0:.*]] = vector.insert %[[RANK_2_0]], %[[UNDEF_RES]] [0] : vector<1x2xf32> into vector<2x1x2xf32> |
27 |
| -// CHECK-UNROLL-NEXT: %[[VEC_1:.*]] = vector.from_elements %[[ARG2]], %[[ARG3]] : vector<2xf32> |
28 |
| -// CHECK-UNROLL-NEXT: %[[RANK_2_1:.*]] = vector.insert %[[VEC_1]], %[[UNDEF_RANK_2]] [0] : vector<2xf32> into vector<1x2xf32> |
29 |
| -// CHECK-UNROLL-NEXT: %[[RES_1:.*]] = vector.insert %[[RANK_2_1]], %[[RES_0]] [1] : vector<1x2xf32> into vector<2x1x2xf32> |
30 |
| -// CHECK-UNROLL-NEXT: return %[[RES_1]] : vector<2x1x2xf32> |
| 21 | +// CHECK-LABEL: @unroll_from_elements_3d |
| 22 | +// CHECK-SAME: (%[[ARG0:.*]]: f32, %[[ARG1:.*]]: f32, %[[ARG2:.*]]: f32, %[[ARG3:.*]]: f32) |
| 23 | +// CHECK-NEXT: %[[UNDEF_RES:.*]] = ub.poison : vector<2x1x2xf32> |
| 24 | +// CHECK-NEXT: %[[UNDEF_RANK_2:.*]] = ub.poison : vector<1x2xf32> |
| 25 | +// CHECK-NEXT: %[[VEC_0:.*]] = vector.from_elements %[[ARG0]], %[[ARG1]] : vector<2xf32> |
| 26 | +// CHECK-NEXT: %[[RANK_2_0:.*]] = vector.insert %[[VEC_0]], %[[UNDEF_RANK_2]] [0] : vector<2xf32> into vector<1x2xf32> |
| 27 | +// CHECK-NEXT: %[[RES_0:.*]] = vector.insert %[[RANK_2_0]], %[[UNDEF_RES]] [0] : vector<1x2xf32> into vector<2x1x2xf32> |
| 28 | +// CHECK-NEXT: %[[VEC_1:.*]] = vector.from_elements %[[ARG2]], %[[ARG3]] : vector<2xf32> |
| 29 | +// CHECK-NEXT: %[[RANK_2_1:.*]] = vector.insert %[[VEC_1]], %[[UNDEF_RANK_2]] [0] : vector<2xf32> into vector<1x2xf32> |
| 30 | +// CHECK-NEXT: %[[RES_1:.*]] = vector.insert %[[RANK_2_1]], %[[RES_0]] [1] : vector<1x2xf32> into vector<2x1x2xf32> |
| 31 | +// CHECK-NEXT: return %[[RES_1]] : vector<2x1x2xf32> |
31 | 32 | func.func @unroll_from_elements_3d(%arg0: f32, %arg1: f32, %arg2: f32, %arg3: f32) -> vector<2x1x2xf32> {
|
32 | 33 | %0 = vector.from_elements %arg0, %arg1, %arg2, %arg3 : vector<2x1x2xf32>
|
33 | 34 | return %0 : vector<2x1x2xf32>
|
34 | 35 | }
|
35 | 36 |
|
36 | 37 | // 1-D vector.from_elements should not be unrolled.
|
37 | 38 |
|
38 |
| -// CHECK-UNROLL-LABEL: @negative_unroll_from_elements_1d |
39 |
| -// CHECK-UNROLL-SAME: (%[[ARG0:.*]]: f32, %[[ARG1:.*]]: f32) |
40 |
| -// CHECK-UNROLL-NEXT: %[[RES:.*]] = vector.from_elements %[[ARG0]], %[[ARG1]] : vector<2xf32> |
41 |
| -// CHECK-UNROLL-NEXT: return %[[RES]] : vector<2xf32> |
| 39 | +// CHECK-LABEL: @negative_unroll_from_elements_1d |
| 40 | +// CHECK-SAME: (%[[ARG0:.*]]: f32, %[[ARG1:.*]]: f32) |
| 41 | +// CHECK-NEXT: %[[RES:.*]] = vector.from_elements %[[ARG0]], %[[ARG1]] : vector<2xf32> |
| 42 | +// CHECK-NEXT: return %[[RES]] : vector<2xf32> |
42 | 43 | func.func @negative_unroll_from_elements_1d(%arg0: f32, %arg1: f32) -> vector<2xf32> {
|
43 | 44 | %0 = vector.from_elements %arg0, %arg1 : vector<2xf32>
|
44 | 45 | return %0 : vector<2xf32>
|
|
0 commit comments