[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / CodeGen / AMDGPU / GlobalISel / inst-select-build-vector-trunc.v2s16.mir
blob3b4f66b82193fdc625d1d99df15dbd91ef7773e9
1 # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
2 # RUN: llc -mtriple=amdgcn-mesa-mesa3d -mcpu=gfx900 -run-pass=instruction-select -verify-machineinstrs -o - %s | FileCheck -check-prefixes=GFX9PLUS,GFX9 %s
3 # RUN: llc -mtriple=amdgcn-mesa-mesa3d -mcpu=gfx1100 -run-pass=instruction-select -verify-machineinstrs -o - %s | FileCheck -check-prefixes=GFX9PLUS,GFX11 %s
5 ---
6 name: test_build_vector_trunc_s_v2s16_s_s32_s_s32
7 legalized:       true
8 regBankSelected: true
9 tracksRegLiveness: true
11 body: |
12   bb.0:
13     liveins: $sgpr0, $sgpr1
15     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_s_s32_s_s32
16     ; GFX9PLUS: liveins: $sgpr0, $sgpr1
17     ; GFX9PLUS-NEXT: {{  $}}
18     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
19     ; GFX9PLUS-NEXT: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
20     ; GFX9PLUS-NEXT: [[S_PACK_LL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LL_B32_B16 [[COPY]], [[COPY1]]
21     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_LL_B32_B16_]]
22     %0:sgpr(s32) = COPY $sgpr0
23     %1:sgpr(s32) = COPY $sgpr1
24     %2:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %0, %1
25     S_ENDPGM 0, implicit %2
26 ...
28 ---
29 name: test_build_vector_trunc_s_pack_lh
30 legalized:       true
31 regBankSelected: true
32 tracksRegLiveness: true
34 body: |
35   bb.0:
36     liveins: $sgpr0, $sgpr1
38     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_pack_lh
39     ; GFX9PLUS: liveins: $sgpr0, $sgpr1
40     ; GFX9PLUS-NEXT: {{  $}}
41     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
42     ; GFX9PLUS-NEXT: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
43     ; GFX9PLUS-NEXT: [[S_PACK_LH_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LH_B32_B16 [[COPY]], [[COPY1]]
44     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_LH_B32_B16_]]
45     %0:sgpr(s32) = COPY $sgpr0
46     %1:sgpr(s32) = COPY $sgpr1
47     %2:sgpr(s32) = G_CONSTANT i32 16
48     %3:sgpr(s32) = G_LSHR %1, %2
49     %4:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %0, %3
50     S_ENDPGM 0, implicit %4
51 ...
53 # s_pack_hl_b32 was introduced in GFX11
54 ---
55 name: test_build_vector_trunc_s_pack_hl
56 legalized:       true
57 regBankSelected: true
58 tracksRegLiveness: true
60 body: |
61   bb.0:
62     liveins: $sgpr0, $sgpr1
64     ; GFX9-LABEL: name: test_build_vector_trunc_s_pack_hl
65     ; GFX9: liveins: $sgpr0, $sgpr1
66     ; GFX9-NEXT: {{  $}}
67     ; GFX9-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
68     ; GFX9-NEXT: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
69     ; GFX9-NEXT: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 16
70     ; GFX9-NEXT: [[S_LSHR_B32_:%[0-9]+]]:sreg_32 = S_LSHR_B32 [[COPY1]], [[S_MOV_B32_]], implicit-def dead $scc
71     ; GFX9-NEXT: [[S_PACK_LL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LL_B32_B16 [[S_LSHR_B32_]], [[COPY]]
72     ; GFX9-NEXT: S_ENDPGM 0, implicit [[S_PACK_LL_B32_B16_]]
73     ;
74     ; GFX11-LABEL: name: test_build_vector_trunc_s_pack_hl
75     ; GFX11: liveins: $sgpr0, $sgpr1
76     ; GFX11-NEXT: {{  $}}
77     ; GFX11-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
78     ; GFX11-NEXT: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
79     ; GFX11-NEXT: [[S_PACK_HL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_HL_B32_B16 [[COPY1]], [[COPY]]
80     ; GFX11-NEXT: S_ENDPGM 0, implicit [[S_PACK_HL_B32_B16_]]
81     %0:sgpr(s32) = COPY $sgpr0
82     %1:sgpr(s32) = COPY $sgpr1
83     %2:sgpr(s32) = G_CONSTANT i32 16
84     %3:sgpr(s32) = G_LSHR %1, %2
85     %4:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %3, %0
86     S_ENDPGM 0, implicit %4
87 ...
89 ---
90 name: test_build_vector_trunc_s_pack_hh
91 legalized:       true
92 regBankSelected: true
93 tracksRegLiveness: true
95 body: |
96   bb.0:
97     liveins: $sgpr0, $sgpr1
99     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_pack_hh
100     ; GFX9PLUS: liveins: $sgpr0, $sgpr1
101     ; GFX9PLUS-NEXT: {{  $}}
102     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
103     ; GFX9PLUS-NEXT: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
104     ; GFX9PLUS-NEXT: [[S_PACK_HH_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_HH_B32_B16 [[COPY]], [[COPY1]]
105     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_HH_B32_B16_]]
106     %0:sgpr(s32) = COPY $sgpr0
107     %1:sgpr(s32) = COPY $sgpr1
108     %2:sgpr(s32) = G_CONSTANT i32 16
109     %3:sgpr(s32) = G_LSHR %0, %2
110     %4:sgpr(s32) = G_LSHR %1, %2
111     %5:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %3, %4
112     S_ENDPGM 0, implicit %5
115 # TODO: Should this use an and instead?
117 name: test_build_vector_trunc_s_v2s16_s_s32_s_0_s32
118 legalized:       true
119 regBankSelected: true
120 tracksRegLiveness: true
122 body: |
123   bb.0:
124     liveins: $sgpr0
126     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_s_s32_s_0_s32
127     ; GFX9PLUS: liveins: $sgpr0
128     ; GFX9PLUS-NEXT: {{  $}}
129     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
130     ; GFX9PLUS-NEXT: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 0
131     ; GFX9PLUS-NEXT: [[S_PACK_LL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LL_B32_B16 [[COPY]], [[S_MOV_B32_]]
132     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_LL_B32_B16_]]
133     %0:sgpr(s32) = COPY $sgpr0
134     %1:sgpr(s32) = G_CONSTANT i32 0
135     %2:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %0, %1
136     S_ENDPGM 0, implicit %2
140 name: test_build_vector_trunc_s_v2s16_s_0_s32_s_s32
141 legalized:       true
142 regBankSelected: true
143 tracksRegLiveness: true
145 body: |
146   bb.0:
147     liveins: $sgpr0
149     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_s_0_s32_s_s32
150     ; GFX9PLUS: liveins: $sgpr0
151     ; GFX9PLUS-NEXT: {{  $}}
152     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
153     ; GFX9PLUS-NEXT: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 0
154     ; GFX9PLUS-NEXT: [[S_PACK_LL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LL_B32_B16 [[S_MOV_B32_]], [[COPY]]
155     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_LL_B32_B16_]]
156     %0:sgpr(s32) = COPY $sgpr0
157     %1:sgpr(s32) = G_CONSTANT i32 0
158     %2:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %1, %0
159     S_ENDPGM 0, implicit %2
163 name: test_build_vector_trunc_s_v2s16_s_s32_s_undef_s32
164 legalized:       true
165 regBankSelected: true
166 tracksRegLiveness: true
168 body: |
169   bb.0:
170     liveins: $sgpr0
172     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_s_s32_s_undef_s32
173     ; GFX9PLUS: liveins: $sgpr0
174     ; GFX9PLUS-NEXT: {{  $}}
175     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
176     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[COPY]]
177     %0:sgpr(s32) = COPY $sgpr0
178     %1:sgpr(s32) = G_IMPLICIT_DEF
179     %2:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %0, %1
180     S_ENDPGM 0, implicit %2
184 name: test_build_vector_trunc_s_v2s16_s_undef_s32_s_s32
185 legalized:       true
186 regBankSelected: true
187 tracksRegLiveness: true
189 body: |
190   bb.0:
191     liveins: $sgpr0
193     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_s_undef_s32_s_s32
194     ; GFX9PLUS: liveins: $sgpr0
195     ; GFX9PLUS-NEXT: {{  $}}
196     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
197     ; GFX9PLUS-NEXT: [[DEF:%[0-9]+]]:sreg_32 = IMPLICIT_DEF
198     ; GFX9PLUS-NEXT: [[S_PACK_LL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LL_B32_B16 [[DEF]], [[COPY]]
199     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_LL_B32_B16_]]
200     %0:sgpr(s32) = COPY $sgpr0
201     %1:sgpr(s32) = G_IMPLICIT_DEF
202     %2:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %1, %0
203     S_ENDPGM 0, implicit %2
207 name: test_build_vector_trunc_s_v2s16_s_undef_s_s32
208 legalized:       true
209 regBankSelected: true
210 tracksRegLiveness: true
212 body: |
213   bb.0:
214     liveins: $sgpr1
216     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_s_undef_s_s32
217     ; GFX9PLUS: liveins: $sgpr1
218     ; GFX9PLUS-NEXT: {{  $}}
219     ; GFX9PLUS-NEXT: [[DEF:%[0-9]+]]:sreg_32 = IMPLICIT_DEF
220     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr1
221     ; GFX9PLUS-NEXT: [[S_PACK_LL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LL_B32_B16 [[DEF]], [[COPY]]
222     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_LL_B32_B16_]]
223     %0:sgpr(s32) = G_IMPLICIT_DEF
224     %1:sgpr(s32) = COPY $sgpr1
225     %2:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %0, %1
226     S_ENDPGM 0, implicit %2
230 name: test_build_vector_trunc_s_v2s16_s_s32_undef
231 legalized:       true
232 regBankSelected: true
233 tracksRegLiveness: true
235 body: |
236   bb.0:
237     liveins: $sgpr0
239     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_s_s32_undef
240     ; GFX9PLUS: liveins: $sgpr0
241     ; GFX9PLUS-NEXT: {{  $}}
242     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
243     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[COPY]]
244     %0:sgpr(s32) = COPY $sgpr0
245     %1:sgpr(s32) = G_IMPLICIT_DEF
246     %2:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %0, %1
247     S_ENDPGM 0, implicit %2
251 name: test_build_vector_trunc_s_v2s16_s_zero_s_s32
252 legalized:       true
253 regBankSelected: true
254 tracksRegLiveness: true
256 body: |
257   bb.0:
258     liveins: $sgpr1
260     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_s_zero_s_s32
261     ; GFX9PLUS: liveins: $sgpr1
262     ; GFX9PLUS-NEXT: {{  $}}
263     ; GFX9PLUS-NEXT: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 0
264     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr1
265     ; GFX9PLUS-NEXT: [[S_PACK_LL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LL_B32_B16 [[S_MOV_B32_]], [[COPY]]
266     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_LL_B32_B16_]]
267     %0:sgpr(s32) = G_CONSTANT i32 0
268     %1:sgpr(s32) = COPY $sgpr1
269     %2:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %0, %1
270     S_ENDPGM 0, implicit %2
274 name: test_build_vector_trunc_s_v2s16_s_s32_zero
275 legalized:       true
276 regBankSelected: true
277 tracksRegLiveness: true
279 body: |
280   bb.0:
281     liveins: $sgpr0
283     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_s_s32_zero
284     ; GFX9PLUS: liveins: $sgpr0
285     ; GFX9PLUS-NEXT: {{  $}}
286     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
287     ; GFX9PLUS-NEXT: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 0
288     ; GFX9PLUS-NEXT: [[S_PACK_LL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LL_B32_B16 [[COPY]], [[S_MOV_B32_]]
289     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_LL_B32_B16_]]
290     %0:sgpr(s32) = COPY $sgpr0
291     %1:sgpr(s32) = G_CONSTANT i32 0
292     %2:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %0, %1
293     S_ENDPGM 0, implicit %2
297 name: test_build_vector_trunc_lshr16_zero
298 legalized:       true
299 regBankSelected: true
300 tracksRegLiveness: true
302 body: |
303   bb.0:
304     liveins: $sgpr0
306     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_lshr16_zero
307     ; GFX9PLUS: liveins: $sgpr0
308     ; GFX9PLUS-NEXT: {{  $}}
309     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
310     ; GFX9PLUS-NEXT: [[S_LSHR_B32_:%[0-9]+]]:sreg_32 = S_LSHR_B32 [[COPY]], 16, implicit-def dead $scc
311     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_LSHR_B32_]]
312     %0:sgpr(s32) = G_CONSTANT i32 0
313     %1:sgpr(s32) = COPY $sgpr0
314     %2:sgpr(s32) = G_CONSTANT i32 16
315     %3:sgpr(s32) = G_LSHR %1, %2
316     %4:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %3, %0
317     S_ENDPGM 0, implicit %4
320 # Don't use pack since it would duplicate the shift use
322 name: test_build_vector_trunc_s_pack_lh_multi_use
323 legalized:       true
324 regBankSelected: true
325 tracksRegLiveness: true
327 body: |
328   bb.0:
329     liveins: $sgpr0, $sgpr1
331     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_pack_lh_multi_use
332     ; GFX9PLUS: liveins: $sgpr0, $sgpr1
333     ; GFX9PLUS-NEXT: {{  $}}
334     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
335     ; GFX9PLUS-NEXT: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
336     ; GFX9PLUS-NEXT: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 16
337     ; GFX9PLUS-NEXT: [[S_LSHR_B32_:%[0-9]+]]:sreg_32 = S_LSHR_B32 [[COPY1]], [[S_MOV_B32_]], implicit-def dead $scc
338     ; GFX9PLUS-NEXT: [[S_PACK_LL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LL_B32_B16 [[COPY]], [[S_LSHR_B32_]]
339     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_LL_B32_B16_]], implicit [[S_LSHR_B32_]]
340     %0:sgpr(s32) = COPY $sgpr0
341     %1:sgpr(s32) = COPY $sgpr1
342     %2:sgpr(s32) = G_CONSTANT i32 16
343     %3:sgpr(s32) = G_LSHR %1, %2
344     %4:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %0, %3
345     S_ENDPGM 0, implicit %4, implicit %3
349 name: test_build_vector_trunc_s_pack_hh_multi_use_lhs
350 legalized:       true
351 regBankSelected: true
352 tracksRegLiveness: true
354 body: |
355   bb.0:
356     liveins: $sgpr0, $sgpr1
358     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_pack_hh_multi_use_lhs
359     ; GFX9PLUS: liveins: $sgpr0, $sgpr1
360     ; GFX9PLUS-NEXT: {{  $}}
361     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
362     ; GFX9PLUS-NEXT: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
363     ; GFX9PLUS-NEXT: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 16
364     ; GFX9PLUS-NEXT: [[S_LSHR_B32_:%[0-9]+]]:sreg_32 = S_LSHR_B32 [[COPY]], [[S_MOV_B32_]], implicit-def dead $scc
365     ; GFX9PLUS-NEXT: [[S_PACK_LH_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LH_B32_B16 [[S_LSHR_B32_]], [[COPY1]]
366     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_LH_B32_B16_]], implicit [[S_LSHR_B32_]]
367     %0:sgpr(s32) = COPY $sgpr0
368     %1:sgpr(s32) = COPY $sgpr1
369     %2:sgpr(s32) = G_CONSTANT i32 16
370     %3:sgpr(s32) = G_LSHR %0, %2
371     %4:sgpr(s32) = G_LSHR %1, %2
372     %5:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %3, %4
373     S_ENDPGM 0, implicit %5, implicit %3
377 name: test_build_vector_trunc_s_pack_hh_multi_use_rhs
378 legalized:       true
379 regBankSelected: true
380 tracksRegLiveness: true
382 body: |
383   bb.0:
384     liveins: $sgpr0, $sgpr1
386     ; GFX9-LABEL: name: test_build_vector_trunc_s_pack_hh_multi_use_rhs
387     ; GFX9: liveins: $sgpr0, $sgpr1
388     ; GFX9-NEXT: {{  $}}
389     ; GFX9-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
390     ; GFX9-NEXT: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
391     ; GFX9-NEXT: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 16
392     ; GFX9-NEXT: [[S_LSHR_B32_:%[0-9]+]]:sreg_32 = S_LSHR_B32 [[COPY]], [[S_MOV_B32_]], implicit-def dead $scc
393     ; GFX9-NEXT: [[S_LSHR_B32_1:%[0-9]+]]:sreg_32 = S_LSHR_B32 [[COPY1]], [[S_MOV_B32_]], implicit-def dead $scc
394     ; GFX9-NEXT: [[S_PACK_LL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LL_B32_B16 [[S_LSHR_B32_]], [[S_LSHR_B32_1]]
395     ; GFX9-NEXT: S_ENDPGM 0, implicit [[S_PACK_LL_B32_B16_]], implicit [[S_LSHR_B32_1]]
396     ;
397     ; GFX11-LABEL: name: test_build_vector_trunc_s_pack_hh_multi_use_rhs
398     ; GFX11: liveins: $sgpr0, $sgpr1
399     ; GFX11-NEXT: {{  $}}
400     ; GFX11-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
401     ; GFX11-NEXT: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
402     ; GFX11-NEXT: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 16
403     ; GFX11-NEXT: [[S_LSHR_B32_:%[0-9]+]]:sreg_32 = S_LSHR_B32 [[COPY1]], [[S_MOV_B32_]], implicit-def dead $scc
404     ; GFX11-NEXT: [[S_PACK_HL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_HL_B32_B16 [[COPY]], [[S_LSHR_B32_]]
405     ; GFX11-NEXT: S_ENDPGM 0, implicit [[S_PACK_HL_B32_B16_]], implicit [[S_LSHR_B32_]]
406     %0:sgpr(s32) = COPY $sgpr0
407     %1:sgpr(s32) = COPY $sgpr1
408     %2:sgpr(s32) = G_CONSTANT i32 16
409     %3:sgpr(s32) = G_LSHR %0, %2
410     %4:sgpr(s32) = G_LSHR %1, %2
411     %5:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %3, %4
412     S_ENDPGM 0, implicit %5, implicit %4
416 name: test_build_vector_trunc_s_pack_lh_wrong_shift_amt
417 legalized:       true
418 regBankSelected: true
419 tracksRegLiveness: true
421 body: |
422   bb.0:
423     liveins: $sgpr0, $sgpr1
425     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_pack_lh_wrong_shift_amt
426     ; GFX9PLUS: liveins: $sgpr0, $sgpr1
427     ; GFX9PLUS-NEXT: {{  $}}
428     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
429     ; GFX9PLUS-NEXT: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
430     ; GFX9PLUS-NEXT: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 15
431     ; GFX9PLUS-NEXT: [[S_LSHR_B32_:%[0-9]+]]:sreg_32 = S_LSHR_B32 [[COPY1]], [[S_MOV_B32_]], implicit-def dead $scc
432     ; GFX9PLUS-NEXT: [[S_PACK_LL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LL_B32_B16 [[COPY]], [[S_LSHR_B32_]]
433     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_LL_B32_B16_]]
434     %0:sgpr(s32) = COPY $sgpr0
435     %1:sgpr(s32) = COPY $sgpr1
436     %2:sgpr(s32) = G_CONSTANT i32 15
437     %3:sgpr(s32) = G_LSHR %1, %2
438     %4:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %0, %3
439     S_ENDPGM 0, implicit %4
443 name: test_build_vector_trunc_s_pack_hh_wrong_shift_amt
444 legalized:       true
445 regBankSelected: true
446 tracksRegLiveness: true
448 body: |
449   bb.0:
450     liveins: $sgpr0, $sgpr1
452     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_pack_hh_wrong_shift_amt
453     ; GFX9PLUS: liveins: $sgpr0, $sgpr1
454     ; GFX9PLUS-NEXT: {{  $}}
455     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
456     ; GFX9PLUS-NEXT: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
457     ; GFX9PLUS-NEXT: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 15
458     ; GFX9PLUS-NEXT: [[S_LSHR_B32_:%[0-9]+]]:sreg_32 = S_LSHR_B32 [[COPY]], [[S_MOV_B32_]], implicit-def dead $scc
459     ; GFX9PLUS-NEXT: [[S_LSHR_B32_1:%[0-9]+]]:sreg_32 = S_LSHR_B32 [[COPY1]], [[S_MOV_B32_]], implicit-def dead $scc
460     ; GFX9PLUS-NEXT: [[S_PACK_LL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LL_B32_B16 [[S_LSHR_B32_]], [[S_LSHR_B32_1]]
461     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_LL_B32_B16_]]
462     %0:sgpr(s32) = COPY $sgpr0
463     %1:sgpr(s32) = COPY $sgpr1
464     %2:sgpr(s32) = G_CONSTANT i32 15
465     %3:sgpr(s32) = G_LSHR %0, %2
466     %4:sgpr(s32) = G_LSHR %1, %2
467     %5:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %3, %4
468     S_ENDPGM 0, implicit %5
472 name: test_build_vector_trunc_s_v2s16_constant_constant
473 legalized:       true
474 regBankSelected: true
475 tracksRegLiveness: true
477 body: |
478   bb.0:
480     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_constant_constant
481     ; GFX9PLUS: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 29884539
482     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_MOV_B32_]]
483     %0:sgpr(s32) = G_CONSTANT i32 123
484     %1:sgpr(s32) = G_CONSTANT i32 456
485     %2:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %0, %1
486     S_ENDPGM 0, implicit %2
490 name: test_build_vector_trunc_s_v2s16_constant_impdef
491 legalized:       true
492 regBankSelected: true
493 tracksRegLiveness: true
495 body: |
496   bb.0:
498     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_constant_impdef
499     ; GFX9PLUS: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 123
500     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_MOV_B32_]]
501     %0:sgpr(s32) = G_CONSTANT i32 123
502     %1:sgpr(s32) = G_IMPLICIT_DEF
503     %2:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %0, %1
504     S_ENDPGM 0, implicit %2
508 name: test_build_vector_trunc_s_v2s16_impdef_constant
509 legalized:       true
510 regBankSelected: true
511 tracksRegLiveness: true
513 body: |
514   bb.0:
516     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_impdef_constant
517     ; GFX9PLUS: [[DEF:%[0-9]+]]:sreg_32 = IMPLICIT_DEF
518     ; GFX9PLUS-NEXT: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 123
519     ; GFX9PLUS-NEXT: [[S_PACK_LL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LL_B32_B16 [[DEF]], [[S_MOV_B32_]]
520     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_LL_B32_B16_]]
521     %0:sgpr(s32) = G_IMPLICIT_DEF
522     %1:sgpr(s32) = G_CONSTANT i32 123
523     %2:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %0, %1
524     S_ENDPGM 0, implicit %2
528 name: test_build_vector_trunc_s_v2s16_impdef_impdef
529 legalized:       true
530 regBankSelected: true
531 tracksRegLiveness: true
533 body: |
534   bb.0:
536     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_impdef_impdef
537     ; GFX9PLUS: [[DEF:%[0-9]+]]:sreg_32 = IMPLICIT_DEF
538     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[DEF]]
539     %0:sgpr(s32) = G_IMPLICIT_DEF
540     %1:sgpr(s32) = G_IMPLICIT_DEF
541     %2:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %0, %1
542     S_ENDPGM 0, implicit %2
546 name: test_build_vector_trunc_s_v2s16_zext_constant_zext_constant
547 legalized:       true
548 regBankSelected: true
549 tracksRegLiveness: true
551 body: |
552   bb.0:
554     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_zext_constant_zext_constant
555     ; GFX9PLUS: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 29884539
556     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_MOV_B32_]]
557     %0:sgpr(s16) = G_CONSTANT i16 123
558     %1:sgpr(s16) = G_CONSTANT i16 456
559     %2:sgpr(s32) = G_ZEXT %0
560     %3:sgpr(s32) = G_ZEXT %1
561     %4:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %2, %3
562     S_ENDPGM 0, implicit %4
566 name: test_build_vector_trunc_s_v2s16_zext_impdef_zext_constant
567 legalized:       true
568 regBankSelected: true
569 tracksRegLiveness: true
571 body: |
572   bb.0:
574     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_zext_impdef_zext_constant
575     ; GFX9PLUS: [[DEF:%[0-9]+]]:sreg_32 = IMPLICIT_DEF
576     ; GFX9PLUS-NEXT: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 123
577     ; GFX9PLUS-NEXT: [[S_MOV_B32_1:%[0-9]+]]:sreg_32 = S_MOV_B32 65535
578     ; GFX9PLUS-NEXT: [[S_AND_B32_:%[0-9]+]]:sreg_32 = S_AND_B32 [[S_MOV_B32_1]], [[DEF]], implicit-def dead $scc
579     ; GFX9PLUS-NEXT: [[S_MOV_B32_2:%[0-9]+]]:sreg_32 = S_MOV_B32 65535
580     ; GFX9PLUS-NEXT: [[S_AND_B32_1:%[0-9]+]]:sreg_32 = S_AND_B32 [[S_MOV_B32_2]], [[S_MOV_B32_]], implicit-def dead $scc
581     ; GFX9PLUS-NEXT: [[S_PACK_LL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LL_B32_B16 [[S_AND_B32_]], [[S_AND_B32_1]]
582     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_LL_B32_B16_]]
583     %0:sgpr(s16) = G_IMPLICIT_DEF
584     %1:sgpr(s16) = G_CONSTANT i16 123
585     %2:sgpr(s32) = G_ZEXT %0
586     %3:sgpr(s32) = G_ZEXT %1
587     %4:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %2, %3
588     S_ENDPGM 0, implicit %4
592 name: test_build_vector_trunc_s_v2s16_sext_constant_sext_constant
593 legalized:       true
594 regBankSelected: true
595 tracksRegLiveness: true
597 body: |
598   bb.0:
600     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_sext_constant_sext_constant
601     ; GFX9PLUS: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 4294836208
602     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_MOV_B32_]]
603     %0:sgpr(s16) = G_CONSTANT i16 -16
604     %1:sgpr(s16) = G_CONSTANT i16 -3
605     %2:sgpr(s32) = G_SEXT %0
606     %3:sgpr(s32) = G_SEXT %1
607     %4:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %2, %3
608     S_ENDPGM 0, implicit %4
612 name: test_build_vector_trunc_s_v2s16_anyext_constant_anyext_constant
613 legalized:       true
614 regBankSelected: true
615 tracksRegLiveness: true
617 body: |
618   bb.0:
620     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_anyext_constant_anyext_constant
621     ; GFX9PLUS: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 29884539
622     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_MOV_B32_]]
623     %0:sgpr(s16) = G_CONSTANT i16 123
624     %1:sgpr(s16) = G_CONSTANT i16 456
625     %2:sgpr(s32) = G_ANYEXT %0
626     %3:sgpr(s32) = G_ANYEXT %1
627     %4:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %2, %3
628     S_ENDPGM 0, implicit %4
632 name: test_build_vector_trunc_s_v2s16_anyext_impdef_anyext_constant
633 legalized:       true
634 regBankSelected: true
635 tracksRegLiveness: true
637 body: |
638   bb.0:
640     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_anyext_impdef_anyext_constant
641     ; GFX9PLUS: [[DEF:%[0-9]+]]:sreg_32 = IMPLICIT_DEF
642     ; GFX9PLUS-NEXT: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 123
643     ; GFX9PLUS-NEXT: [[S_PACK_LL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LL_B32_B16 [[DEF]], [[S_MOV_B32_]]
644     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_LL_B32_B16_]]
645     %0:sgpr(s16) = G_IMPLICIT_DEF
646     %1:sgpr(s16) = G_CONSTANT i16 123
647     %2:sgpr(s32) = G_ANYEXT %0
648     %3:sgpr(s32) = G_ANYEXT %1
649     %4:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %2, %3
650     S_ENDPGM 0, implicit %4
654 name: test_build_vector_trunc_s_v2s16_var_constant
655 legalized:       true
656 regBankSelected: true
657 tracksRegLiveness: true
659 body: |
660   bb.0:
661     liveins: $sgpr0
663     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_var_constant
664     ; GFX9PLUS: liveins: $sgpr0
665     ; GFX9PLUS-NEXT: {{  $}}
666     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
667     ; GFX9PLUS-NEXT: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 456
668     ; GFX9PLUS-NEXT: [[S_PACK_LL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LL_B32_B16 [[COPY]], [[S_MOV_B32_]]
669     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_LL_B32_B16_]]
670     %0:sgpr(s32) = COPY $sgpr0
671     %1:sgpr(s32) = G_CONSTANT i32 456
672     %2:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %0, %1
673     S_ENDPGM 0, implicit %2
677 name: test_build_vector_trunc_s_v2s16_constant_var
678 legalized:       true
679 regBankSelected: true
680 tracksRegLiveness: true
682 body: |
683   bb.0:
684     liveins: $sgpr0
686     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_constant_var
687     ; GFX9PLUS: liveins: $sgpr0
688     ; GFX9PLUS-NEXT: {{  $}}
689     ; GFX9PLUS-NEXT: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 456
690     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
691     ; GFX9PLUS-NEXT: [[S_PACK_LL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LL_B32_B16 [[S_MOV_B32_]], [[COPY]]
692     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_LL_B32_B16_]]
693     %0:sgpr(s32) = G_CONSTANT i32 456
694     %1:sgpr(s32) = COPY $sgpr0
695     %2:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %0, %1
696     S_ENDPGM 0, implicit %2
700 name: test_build_vector_trunc_s_v2s16_var_0
701 legalized:       true
702 regBankSelected: true
703 tracksRegLiveness: true
705 body: |
706   bb.0:
707     liveins: $sgpr0
709     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_var_0
710     ; GFX9PLUS: liveins: $sgpr0
711     ; GFX9PLUS-NEXT: {{  $}}
712     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
713     ; GFX9PLUS-NEXT: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 0
714     ; GFX9PLUS-NEXT: [[S_PACK_LL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LL_B32_B16 [[COPY]], [[S_MOV_B32_]]
715     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_LL_B32_B16_]]
716     %0:sgpr(s32) = COPY $sgpr0
717     %1:sgpr(s32) = G_CONSTANT i32 0
718     %2:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %0, %1
719     S_ENDPGM 0, implicit %2
723 name: test_build_vector_trunc_s_v2s16_0_var
724 legalized:       true
725 regBankSelected: true
726 tracksRegLiveness: true
728 body: |
729   bb.0:
730     liveins: $sgpr0
732     ; GFX9PLUS-LABEL: name: test_build_vector_trunc_s_v2s16_0_var
733     ; GFX9PLUS: liveins: $sgpr0
734     ; GFX9PLUS-NEXT: {{  $}}
735     ; GFX9PLUS-NEXT: [[S_MOV_B32_:%[0-9]+]]:sreg_32 = S_MOV_B32 0
736     ; GFX9PLUS-NEXT: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
737     ; GFX9PLUS-NEXT: [[S_PACK_LL_B32_B16_:%[0-9]+]]:sreg_32 = S_PACK_LL_B32_B16 [[S_MOV_B32_]], [[COPY]]
738     ; GFX9PLUS-NEXT: S_ENDPGM 0, implicit [[S_PACK_LL_B32_B16_]]
739     %0:sgpr(s32) = G_CONSTANT i32 0
740     %1:sgpr(s32) = COPY $sgpr0
741     %2:sgpr(<2 x s16>) = G_BUILD_VECTOR_TRUNC %0, %1
742     S_ENDPGM 0, implicit %2