Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / AMDGPU / GlobalISel / regbankselect-concat-vector.mir
blob88e0348cb53b38de0e367e360636197e7fe9f826
1 # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
2 # RUN: llc -march=amdgcn -mcpu=gfx908 -run-pass=amdgpu-regbankselect -regbankselect-fast -verify-machineinstrs -o - %s | FileCheck %s
3 # RUN: llc -march=amdgcn -mcpu=gfx908 -run-pass=amdgpu-regbankselect -regbankselect-greedy -verify-machineinstrs -o - %s | FileCheck %s
5 ---
6 name: concat_vectors_v4s16_ss
7 legalized: true
9 body: |
10   bb.0:
11     liveins: $sgpr0, $sgpr1
12     ; CHECK-LABEL: name: concat_vectors_v4s16_ss
13     ; CHECK: liveins: $sgpr0, $sgpr1
14     ; CHECK-NEXT: {{  $}}
15     ; CHECK-NEXT: [[COPY:%[0-9]+]]:sgpr(<2 x s16>) = COPY $sgpr0
16     ; CHECK-NEXT: [[COPY1:%[0-9]+]]:sgpr(<2 x s16>) = COPY $sgpr1
17     ; CHECK-NEXT: [[CONCAT_VECTORS:%[0-9]+]]:sgpr(<4 x s16>) = G_CONCAT_VECTORS [[COPY]](<2 x s16>), [[COPY1]](<2 x s16>)
18     %0:_(<2 x s16>) = COPY $sgpr0
19     %1:_(<2 x s16>) = COPY $sgpr1
20     %2:_(<4 x s16>) = G_CONCAT_VECTORS %0, %1
21 ...
23 ---
24 name: concat_vectors_v4s16_sv
25 legalized: true
27 body: |
28   bb.0:
29     liveins: $sgpr0, $vgpr0
30     ; CHECK-LABEL: name: concat_vectors_v4s16_sv
31     ; CHECK: liveins: $sgpr0, $vgpr0
32     ; CHECK-NEXT: {{  $}}
33     ; CHECK-NEXT: [[COPY:%[0-9]+]]:sgpr(<2 x s16>) = COPY $sgpr0
34     ; CHECK-NEXT: [[COPY1:%[0-9]+]]:vgpr(<2 x s16>) = COPY $vgpr0
35     ; CHECK-NEXT: [[COPY2:%[0-9]+]]:vgpr(<2 x s16>) = COPY [[COPY]](<2 x s16>)
36     ; CHECK-NEXT: [[CONCAT_VECTORS:%[0-9]+]]:vgpr(<4 x s16>) = G_CONCAT_VECTORS [[COPY2]](<2 x s16>), [[COPY1]](<2 x s16>)
37     %0:_(<2 x s16>) = COPY $sgpr0
38     %1:_(<2 x s16>) = COPY $vgpr0
39     %2:_(<4 x s16>) = G_CONCAT_VECTORS %0, %1
40 ...
42 ---
43 name: concat_vectors_v4s16_vs
44 legalized: true
46 body: |
47   bb.0:
48     liveins: $vgpr0, $sgpr0
49     ; CHECK-LABEL: name: concat_vectors_v4s16_vs
50     ; CHECK: liveins: $vgpr0, $sgpr0
51     ; CHECK-NEXT: {{  $}}
52     ; CHECK-NEXT: [[COPY:%[0-9]+]]:vgpr(<2 x s16>) = COPY $vgpr0
53     ; CHECK-NEXT: [[COPY1:%[0-9]+]]:sgpr(<2 x s16>) = COPY $sgpr0
54     ; CHECK-NEXT: [[COPY2:%[0-9]+]]:vgpr(<2 x s16>) = COPY [[COPY1]](<2 x s16>)
55     ; CHECK-NEXT: [[CONCAT_VECTORS:%[0-9]+]]:vgpr(<4 x s16>) = G_CONCAT_VECTORS [[COPY]](<2 x s16>), [[COPY2]](<2 x s16>)
56     %0:_(<2 x s16>) = COPY $vgpr0
57     %1:_(<2 x s16>) = COPY $sgpr0
58     %2:_(<4 x s16>) = G_CONCAT_VECTORS %0, %1
59 ...
61 ---
62 name: concat_vectors_v4s16_vv
63 legalized: true
65 body: |
66   bb.0:
67     liveins: $vgpr0, $vgpr1
68     ; CHECK-LABEL: name: concat_vectors_v4s16_vv
69     ; CHECK: liveins: $vgpr0, $vgpr1
70     ; CHECK-NEXT: {{  $}}
71     ; CHECK-NEXT: [[COPY:%[0-9]+]]:vgpr(<2 x s16>) = COPY $vgpr0
72     ; CHECK-NEXT: [[COPY1:%[0-9]+]]:vgpr(<2 x s16>) = COPY $vgpr1
73     ; CHECK-NEXT: [[CONCAT_VECTORS:%[0-9]+]]:vgpr(<4 x s16>) = G_CONCAT_VECTORS [[COPY]](<2 x s16>), [[COPY1]](<2 x s16>)
74     %0:_(<2 x s16>) = COPY $vgpr0
75     %1:_(<2 x s16>) = COPY $vgpr1
76     %2:_(<4 x s16>) = G_CONCAT_VECTORS %0, %1
77 ...
79 ---
80 name: concat_vectors_v4s16_aa
81 legalized: true
83 body: |
84   bb.0:
85     liveins: $agpr0, $agpr1
86     ; CHECK-LABEL: name: concat_vectors_v4s16_aa
87     ; CHECK: liveins: $agpr0, $agpr1
88     ; CHECK-NEXT: {{  $}}
89     ; CHECK-NEXT: [[COPY:%[0-9]+]]:agpr(<2 x s16>) = COPY $agpr0
90     ; CHECK-NEXT: [[COPY1:%[0-9]+]]:agpr(<2 x s16>) = COPY $agpr1
91     ; CHECK-NEXT: [[CONCAT_VECTORS:%[0-9]+]]:agpr(<4 x s16>) = G_CONCAT_VECTORS [[COPY]](<2 x s16>), [[COPY1]](<2 x s16>)
92     ; CHECK-NEXT: S_ENDPGM 0, implicit [[CONCAT_VECTORS]](<4 x s16>)
93     %0:_(<2 x s16>) = COPY $agpr0
94     %1:_(<2 x s16>) = COPY $agpr1
95     %2:_(<4 x s16>) = G_CONCAT_VECTORS %0, %1
96     S_ENDPGM 0, implicit %2
97 ...
99 ---
100 name: concat_vectors_v4s16_av
101 legalized: true
103 body: |
104   bb.0:
105     liveins: $agpr0, $vgpr0
106     ; CHECK-LABEL: name: concat_vectors_v4s16_av
107     ; CHECK: liveins: $agpr0, $vgpr0
108     ; CHECK-NEXT: {{  $}}
109     ; CHECK-NEXT: [[COPY:%[0-9]+]]:agpr(<2 x s16>) = COPY $agpr0
110     ; CHECK-NEXT: [[COPY1:%[0-9]+]]:vgpr(<2 x s16>) = COPY $vgpr0
111     ; CHECK-NEXT: [[COPY2:%[0-9]+]]:vgpr(<2 x s16>) = COPY [[COPY]](<2 x s16>)
112     ; CHECK-NEXT: [[CONCAT_VECTORS:%[0-9]+]]:vgpr(<4 x s16>) = G_CONCAT_VECTORS [[COPY2]](<2 x s16>), [[COPY1]](<2 x s16>)
113     ; CHECK-NEXT: S_ENDPGM 0, implicit [[CONCAT_VECTORS]](<4 x s16>)
114     %0:_(<2 x s16>) = COPY $agpr0
115     %1:_(<2 x s16>) = COPY $vgpr0
116     %2:_(<4 x s16>) = G_CONCAT_VECTORS %0, %1
117     S_ENDPGM 0, implicit %2
121 name: concat_vectors_v4s16_va
122 legalized: true
124 body: |
125   bb.0:
126     liveins: $agpr0, $vgpr0
127     ; CHECK-LABEL: name: concat_vectors_v4s16_va
128     ; CHECK: liveins: $agpr0, $vgpr0
129     ; CHECK-NEXT: {{  $}}
130     ; CHECK-NEXT: [[COPY:%[0-9]+]]:vgpr(<2 x s16>) = COPY $vgpr0
131     ; CHECK-NEXT: [[COPY1:%[0-9]+]]:agpr(<2 x s16>) = COPY $agpr0
132     ; CHECK-NEXT: [[COPY2:%[0-9]+]]:vgpr(<2 x s16>) = COPY [[COPY1]](<2 x s16>)
133     ; CHECK-NEXT: [[CONCAT_VECTORS:%[0-9]+]]:vgpr(<4 x s16>) = G_CONCAT_VECTORS [[COPY]](<2 x s16>), [[COPY2]](<2 x s16>)
134     ; CHECK-NEXT: S_ENDPGM 0, implicit [[CONCAT_VECTORS]](<4 x s16>)
135     %0:_(<2 x s16>) = COPY $vgpr0
136     %1:_(<2 x s16>) = COPY $agpr0
137     %2:_(<4 x s16>) = G_CONCAT_VECTORS %0, %1
138     S_ENDPGM 0, implicit %2
142 name: concat_vectors_v4s16_as
143 legalized: true
145 body: |
146   bb.0:
147     liveins: $agpr0, $sgpr0
148     ; CHECK-LABEL: name: concat_vectors_v4s16_as
149     ; CHECK: liveins: $agpr0, $sgpr0
150     ; CHECK-NEXT: {{  $}}
151     ; CHECK-NEXT: [[COPY:%[0-9]+]]:agpr(<2 x s16>) = COPY $agpr0
152     ; CHECK-NEXT: [[COPY1:%[0-9]+]]:sgpr(<2 x s16>) = COPY $sgpr0
153     ; CHECK-NEXT: [[COPY2:%[0-9]+]]:vgpr(<2 x s16>) = COPY [[COPY]](<2 x s16>)
154     ; CHECK-NEXT: [[COPY3:%[0-9]+]]:vgpr(<2 x s16>) = COPY [[COPY1]](<2 x s16>)
155     ; CHECK-NEXT: [[CONCAT_VECTORS:%[0-9]+]]:vgpr(<4 x s16>) = G_CONCAT_VECTORS [[COPY2]](<2 x s16>), [[COPY3]](<2 x s16>)
156     ; CHECK-NEXT: S_ENDPGM 0, implicit [[CONCAT_VECTORS]](<4 x s16>)
157     %0:_(<2 x s16>) = COPY $agpr0
158     %1:_(<2 x s16>) = COPY $sgpr0
159     %2:_(<4 x s16>) = G_CONCAT_VECTORS %0, %1
160     S_ENDPGM 0, implicit %2
164 name: concat_vectors_v4s16_sa
165 legalized: true
167 body: |
168   bb.0:
169     liveins: $agpr0, $sgpr0
170     ; CHECK-LABEL: name: concat_vectors_v4s16_sa
171     ; CHECK: liveins: $agpr0, $sgpr0
172     ; CHECK-NEXT: {{  $}}
173     ; CHECK-NEXT: [[COPY:%[0-9]+]]:sgpr(<2 x s16>) = COPY $sgpr0
174     ; CHECK-NEXT: [[COPY1:%[0-9]+]]:agpr(<2 x s16>) = COPY $agpr0
175     ; CHECK-NEXT: [[COPY2:%[0-9]+]]:vgpr(<2 x s16>) = COPY [[COPY]](<2 x s16>)
176     ; CHECK-NEXT: [[COPY3:%[0-9]+]]:vgpr(<2 x s16>) = COPY [[COPY1]](<2 x s16>)
177     ; CHECK-NEXT: [[CONCAT_VECTORS:%[0-9]+]]:vgpr(<4 x s16>) = G_CONCAT_VECTORS [[COPY2]](<2 x s16>), [[COPY3]](<2 x s16>)
178     ; CHECK-NEXT: S_ENDPGM 0, implicit [[CONCAT_VECTORS]](<4 x s16>)
179     %0:_(<2 x s16>) = COPY $sgpr0
180     %1:_(<2 x s16>) = COPY $agpr0
181     %2:_(<4 x s16>) = G_CONCAT_VECTORS %0, %1
182     S_ENDPGM 0, implicit %2