1 ; RUN: llc -march=amdgcn -verify-machineinstrs < %s | FileCheck -allow-deprecated-dag-overlap -check-prefixes=GCN,SI,SICIVI,FUNC %s
2 ; RUN: llc -march=amdgcn -mcpu=tonga -verify-machineinstrs < %s | FileCheck -allow-deprecated-dag-overlap -check-prefixes=GCN,SICIVI,GFX89,FUNC %s
3 ; RUN: llc -march=amdgcn -mcpu=gfx900 -verify-machineinstrs < %s | FileCheck -allow-deprecated-dag-overlap -check-prefixes=GCN,GFX9,GFX89,FUNC %s
4 ; RUN: llc -march=r600 -mcpu=redwood -verify-machineinstrs < %s | FileCheck -allow-deprecated-dag-overlap -check-prefix=EG -check-prefix=FUNC %s
6 ; Testing for ds_read/write_b128
7 ; RUN: llc -march=amdgcn -mcpu=tonga -mattr=+enable-ds128 < %s | FileCheck -allow-deprecated-dag-overlap -check-prefixes=CIVI,FUNC %s
8 ; RUN: llc -march=amdgcn -mcpu=gfx900 -mattr=+enable-ds128 < %s | FileCheck -allow-deprecated-dag-overlap -check-prefixes=CIVI,FUNC %s
10 ; FUNC-LABEL: {{^}}local_load_i16:
12 ; SICIVI: s_mov_b32 m0
14 ; GCN: ds_read_u16 v{{[0-9]+}}
16 ; EG: MOV {{[* ]*}}[[FROM:T[0-9]+\.[XYZW]]], KC0[2].Z
17 ; EG: LDS_USHORT_READ_RET {{.*}} [[FROM]]
18 ; EG-DAG: MOV {{[* ]*}}[[DATA:T[0-9]+\.[XYZW]]], OQAP
19 ; EG-DAG: MOV {{[* ]*}}[[TO:T[0-9]+\.[XYZW]]], KC0[2].Y
20 ; EG: LDS_SHORT_WRITE {{\*?}} [[TO]], [[DATA]]
21 define amdgpu_kernel void @local_load_i16(i16 addrspace(3)* %out, i16 addrspace(3)* %in) {
23 %ld = load i16, i16 addrspace(3)* %in
24 store i16 %ld, i16 addrspace(3)* %out
28 ; FUNC-LABEL: {{^}}local_load_v2i16:
30 ; SICIVI: s_mov_b32 m0
34 ; EG: MOV {{[* ]*}}[[FROM:T[0-9]+\.[XYZW]]], KC0[2].Z
35 ; EG: LDS_READ_RET {{.*}} [[FROM]]
36 ; EG-DAG: MOV {{[* ]*}}[[DATA:T[0-9]+\.[XYZW]]], OQAP
37 ; EG-DAG: MOV {{[* ]*}}[[TO:T[0-9]+\.[XYZW]]], KC0[2].Y
38 ; EG: LDS_WRITE {{\*?}} [[TO]], [[DATA]]
39 define amdgpu_kernel void @local_load_v2i16(<2 x i16> addrspace(3)* %out, <2 x i16> addrspace(3)* %in) {
41 %ld = load <2 x i16>, <2 x i16> addrspace(3)* %in
42 store <2 x i16> %ld, <2 x i16> addrspace(3)* %out
46 ; FUNC-LABEL: {{^}}local_load_v3i16:
48 ; SICIVI: s_mov_b32 m0
51 ; GCN-DAG: ds_write_b32
52 ; GCN-DAG: ds_write_b16
54 ; EG-DAG: LDS_USHORT_READ_RET
55 ; EG-DAG: LDS_READ_RET
56 define amdgpu_kernel void @local_load_v3i16(<3 x i16> addrspace(3)* %out, <3 x i16> addrspace(3)* %in) {
58 %ld = load <3 x i16>, <3 x i16> addrspace(3)* %in
59 store <3 x i16> %ld, <3 x i16> addrspace(3)* %out
63 ; FUNC-LABEL: {{^}}local_load_v4i16:
65 ; SICIVI: s_mov_b32 m0
71 define amdgpu_kernel void @local_load_v4i16(<4 x i16> addrspace(3)* %out, <4 x i16> addrspace(3)* %in) {
73 %ld = load <4 x i16>, <4 x i16> addrspace(3)* %in
74 store <4 x i16> %ld, <4 x i16> addrspace(3)* %out
78 ; FUNC-LABEL: {{^}}local_load_v8i16:
80 ; SICIVI: s_mov_b32 m0
82 ; GCN: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset1:1{{$}}
88 define amdgpu_kernel void @local_load_v8i16(<8 x i16> addrspace(3)* %out, <8 x i16> addrspace(3)* %in) {
90 %ld = load <8 x i16>, <8 x i16> addrspace(3)* %in
91 store <8 x i16> %ld, <8 x i16> addrspace(3)* %out
95 ; FUNC-LABEL: {{^}}local_load_v16i16:
97 ; SICIVI: s_mov_b32 m0
99 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset0:2 offset1:3{{$}}
100 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset1:1{{$}}
112 define amdgpu_kernel void @local_load_v16i16(<16 x i16> addrspace(3)* %out, <16 x i16> addrspace(3)* %in) {
114 %ld = load <16 x i16>, <16 x i16> addrspace(3)* %in
115 store <16 x i16> %ld, <16 x i16> addrspace(3)* %out
119 ; FUNC-LABEL: {{^}}local_zextload_i16_to_i32:
121 ; SICIVI: s_mov_b32 m0
126 ; EG: MOV {{[* ]*}}[[FROM:T[0-9]+\.[XYZW]]], KC0[2].Z
127 ; EG: LDS_USHORT_READ_RET {{.*}} [[FROM]]
128 ; EG-DAG: MOV {{[* ]*}}[[DATA:T[0-9]+\.[XYZW]]], OQAP
129 ; EG-DAG: MOV {{[* ]*}}[[TO:T[0-9]+\.[XYZW]]], KC0[2].Y
130 ; EG: LDS_WRITE {{\*?}} [[TO]], [[DATA]]
131 define amdgpu_kernel void @local_zextload_i16_to_i32(i32 addrspace(3)* %out, i16 addrspace(3)* %in) #0 {
132 %a = load i16, i16 addrspace(3)* %in
133 %ext = zext i16 %a to i32
134 store i32 %ext, i32 addrspace(3)* %out
138 ; FUNC-LABEL: {{^}}local_sextload_i16_to_i32:
142 ; SICIVI: s_mov_b32 m0
146 ; EG: MOV {{[* ]*}}[[FROM:T[0-9]+\.[XYZW]]], KC0[2].Z
147 ; EG: LDS_USHORT_READ_RET {{.*}} [[FROM]]
148 ; EG-DAG: MOV {{[* ]*}}[[TMP:T[0-9]+\.[XYZW]]], OQAP
149 ; EG-DAG: MOV {{[* ]*}}[[TO:T[0-9]+\.[XYZW]]], KC0[2].Y
150 ; EG-DAG: BFE_INT {{[* ]*}}[[DATA:T[0-9]+\.[XYZW]]], {{.*}}, 0.0, literal
152 ; EG: LDS_WRITE {{\*?}} [[TO]], [[DATA]]
153 define amdgpu_kernel void @local_sextload_i16_to_i32(i32 addrspace(3)* %out, i16 addrspace(3)* %in) #0 {
154 %a = load i16, i16 addrspace(3)* %in
155 %ext = sext i16 %a to i32
156 store i32 %ext, i32 addrspace(3)* %out
160 ; FUNC-LABEL: {{^}}local_zextload_v1i16_to_v1i32:
162 ; SICIVI: s_mov_b32 m0
166 ; EG: MOV {{[* ]*}}[[FROM:T[0-9]+\.[XYZW]]], KC0[2].Z
167 ; EG: LDS_USHORT_READ_RET {{.*}} [[FROM]]
168 ; EG-DAG: MOV {{[* ]*}}[[DATA:T[0-9]+\.[XYZW]]], OQAP
169 ; EG-DAG: MOV {{[* ]*}}[[TO:T[0-9]+\.[XYZW]]], KC0[2].Y
170 ; EG: LDS_WRITE {{\*?}} [[TO]], [[DATA]]
171 define amdgpu_kernel void @local_zextload_v1i16_to_v1i32(<1 x i32> addrspace(3)* %out, <1 x i16> addrspace(3)* %in) #0 {
172 %load = load <1 x i16>, <1 x i16> addrspace(3)* %in
173 %ext = zext <1 x i16> %load to <1 x i32>
174 store <1 x i32> %ext, <1 x i32> addrspace(3)* %out
178 ; FUNC-LABEL: {{^}}local_sextload_v1i16_to_v1i32:
180 ; SICIVI: s_mov_b32 m0
184 ; EG: MOV {{[* ]*}}[[FROM:T[0-9]+\.[XYZW]]], KC0[2].Z
185 ; EG: LDS_USHORT_READ_RET {{.*}} [[FROM]]
186 ; EG-DAG: MOV {{[* ]*}}[[TMP:T[0-9]+\.[XYZW]]], OQAP
187 ; EG-DAG: MOV {{[* ]*}}[[TO:T[0-9]+\.[XYZW]]], KC0[2].Y
188 ; EG-DAG: BFE_INT {{[* ]*}}[[DATA:T[0-9]+\.[XYZW]]], {{.*}}, 0.0, literal
190 ; EG: LDS_WRITE {{\*?}} [[TO]], [[DATA]]
191 define amdgpu_kernel void @local_sextload_v1i16_to_v1i32(<1 x i32> addrspace(3)* %out, <1 x i16> addrspace(3)* %in) #0 {
192 %load = load <1 x i16>, <1 x i16> addrspace(3)* %in
193 %ext = sext <1 x i16> %load to <1 x i32>
194 store <1 x i32> %ext, <1 x i32> addrspace(3)* %out
198 ; FUNC-LABEL: {{^}}local_zextload_v2i16_to_v2i32:
201 ; SICIVI: s_mov_b32 m0
206 define amdgpu_kernel void @local_zextload_v2i16_to_v2i32(<2 x i32> addrspace(3)* %out, <2 x i16> addrspace(3)* %in) #0 {
207 %load = load <2 x i16>, <2 x i16> addrspace(3)* %in
208 %ext = zext <2 x i16> %load to <2 x i32>
209 store <2 x i32> %ext, <2 x i32> addrspace(3)* %out
213 ; FUNC-LABEL: {{^}}local_sextload_v2i16_to_v2i32:
216 ; SICIVI: s_mov_b32 m0
223 define amdgpu_kernel void @local_sextload_v2i16_to_v2i32(<2 x i32> addrspace(3)* %out, <2 x i16> addrspace(3)* %in) #0 {
224 %load = load <2 x i16>, <2 x i16> addrspace(3)* %in
225 %ext = sext <2 x i16> %load to <2 x i32>
226 store <2 x i32> %ext, <2 x i32> addrspace(3)* %out
230 ; FUNC-LABEL: {{^}}local_local_zextload_v3i16_to_v3i32:
232 ; SICIVI: s_mov_b32 m0
235 ; GCN-DAG: ds_write_b32
236 ; GCN-DAG: ds_write_b64
239 define amdgpu_kernel void @local_local_zextload_v3i16_to_v3i32(<3 x i32> addrspace(3)* %out, <3 x i16> addrspace(3)* %in) {
241 %ld = load <3 x i16>, <3 x i16> addrspace(3)* %in
242 %ext = zext <3 x i16> %ld to <3 x i32>
243 store <3 x i32> %ext, <3 x i32> addrspace(3)* %out
247 ; FUNC-LABEL: {{^}}local_local_sextload_v3i16_to_v3i32:
249 ; SICIVI: s_mov_b32 m0
252 ; GCN-DAG: ds_write_b32
253 ; GCN-DAG: ds_write_b64
259 define amdgpu_kernel void @local_local_sextload_v3i16_to_v3i32(<3 x i32> addrspace(3)* %out, <3 x i16> addrspace(3)* %in) {
261 %ld = load <3 x i16>, <3 x i16> addrspace(3)* %in
262 %ext = sext <3 x i16> %ld to <3 x i32>
263 store <3 x i32> %ext, <3 x i32> addrspace(3)* %out
267 ; FUNC-LABEL: {{^}}local_local_zextload_v4i16_to_v4i32:
270 ; SICIVI: s_mov_b32 m0
276 define amdgpu_kernel void @local_local_zextload_v4i16_to_v4i32(<4 x i32> addrspace(3)* %out, <4 x i16> addrspace(3)* %in) #0 {
277 %load = load <4 x i16>, <4 x i16> addrspace(3)* %in
278 %ext = zext <4 x i16> %load to <4 x i32>
279 store <4 x i32> %ext, <4 x i32> addrspace(3)* %out
283 ; FUNC-LABEL: {{^}}local_sextload_v4i16_to_v4i32:
286 ; SICIVI: s_mov_b32 m0
296 define amdgpu_kernel void @local_sextload_v4i16_to_v4i32(<4 x i32> addrspace(3)* %out, <4 x i16> addrspace(3)* %in) #0 {
297 %load = load <4 x i16>, <4 x i16> addrspace(3)* %in
298 %ext = sext <4 x i16> %load to <4 x i32>
299 store <4 x i32> %ext, <4 x i32> addrspace(3)* %out
303 ; FUNC-LABEL: {{^}}local_zextload_v8i16_to_v8i32:
305 ; SICIVI: s_mov_b32 m0
307 ; GCN: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset1:1{{$}}
313 define amdgpu_kernel void @local_zextload_v8i16_to_v8i32(<8 x i32> addrspace(3)* %out, <8 x i16> addrspace(3)* %in) #0 {
314 %load = load <8 x i16>, <8 x i16> addrspace(3)* %in
315 %ext = zext <8 x i16> %load to <8 x i32>
316 store <8 x i32> %ext, <8 x i32> addrspace(3)* %out
320 ; FUNC-LABEL: {{^}}local_sextload_v8i16_to_v8i32:
322 ; SICIVI: s_mov_b32 m0
324 ; GCN: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset1:1{{$}}
338 define amdgpu_kernel void @local_sextload_v8i16_to_v8i32(<8 x i32> addrspace(3)* %out, <8 x i16> addrspace(3)* %in) #0 {
339 %load = load <8 x i16>, <8 x i16> addrspace(3)* %in
340 %ext = sext <8 x i16> %load to <8 x i32>
341 store <8 x i32> %ext, <8 x i32> addrspace(3)* %out
345 ; FUNC-LABEL: {{^}}local_zextload_v16i16_to_v16i32:
347 ; SICIVI: s_mov_b32 m0
349 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset1:1{{$}}
350 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset0:2 offset1:3{{$}}
365 define amdgpu_kernel void @local_zextload_v16i16_to_v16i32(<16 x i32> addrspace(3)* %out, <16 x i16> addrspace(3)* %in) #0 {
366 %load = load <16 x i16>, <16 x i16> addrspace(3)* %in
367 %ext = zext <16 x i16> %load to <16 x i32>
368 store <16 x i32> %ext, <16 x i32> addrspace(3)* %out
372 ; FUNC-LABEL: {{^}}local_sextload_v16i16_to_v16i32:
374 ; SICIVI: s_mov_b32 m0
377 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset1:1{{$}}
378 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset0:2 offset1:3{{$}}
404 define amdgpu_kernel void @local_sextload_v16i16_to_v16i32(<16 x i32> addrspace(3)* %out, <16 x i16> addrspace(3)* %in) #0 {
405 %load = load <16 x i16>, <16 x i16> addrspace(3)* %in
406 %ext = sext <16 x i16> %load to <16 x i32>
407 store <16 x i32> %ext, <16 x i32> addrspace(3)* %out
411 ; FUNC-LABEL: {{^}}local_zextload_v32i16_to_v32i32:
413 ; SICIVI: s_mov_b32 m0
415 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset1:1{{$}}
416 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset0:2 offset1:3
417 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset0:4 offset1:5
418 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset0:6 offset1:7
436 define amdgpu_kernel void @local_zextload_v32i16_to_v32i32(<32 x i32> addrspace(3)* %out, <32 x i16> addrspace(3)* %in) #0 {
437 %load = load <32 x i16>, <32 x i16> addrspace(3)* %in
438 %ext = zext <32 x i16> %load to <32 x i32>
439 store <32 x i32> %ext, <32 x i32> addrspace(3)* %out
443 ; FUNC-LABEL: {{^}}local_sextload_v32i16_to_v32i32:
445 ; SICIVI: s_mov_b32 m0
447 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset0:2 offset1:3{{$}}
448 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset0:4 offset1:5
449 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset1:1{{$}}
450 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset0:6 offset1:7
451 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:14 offset1:15
452 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:12 offset1:13
453 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:10 offset1:11
454 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:8 offset1:9
455 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:6 offset1:7
456 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:4 offset1:5
457 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:2 offset1:3
458 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset1:1
476 define amdgpu_kernel void @local_sextload_v32i16_to_v32i32(<32 x i32> addrspace(3)* %out, <32 x i16> addrspace(3)* %in) #0 {
477 %load = load <32 x i16>, <32 x i16> addrspace(3)* %in
478 %ext = sext <32 x i16> %load to <32 x i32>
479 store <32 x i32> %ext, <32 x i32> addrspace(3)* %out
483 ; FUNC-LABEL: {{^}}local_zextload_v64i16_to_v64i32:
485 ; SICIVI: s_mov_b32 m0
487 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset0:14 offset1:15
488 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset1:1{{$}}
489 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset0:2 offset1:3
490 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset0:4 offset1:5
491 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset0:6 offset1:7
492 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset0:8 offset1:9
493 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset0:12 offset1:13
494 ; GCN-DAG: ds_read2_b64 v{{\[[0-9]+:[0-9]+\]}}, v{{[0-9]+}} offset0:10 offset1:11
495 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:30 offset1:31
496 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:28 offset1:29
497 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:26 offset1:27
498 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:24 offset1:25
499 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:22 offset1:23
500 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:20 offset1:21
501 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:18 offset1:19
502 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:16 offset1:17
503 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:14 offset1:15
504 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:12 offset1:13
505 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:10 offset1:11
506 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:8 offset1:9
507 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:6 offset1:7
508 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:4 offset1:5
509 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset0:2 offset1:3
510 ; GCN-DAG: ds_write2_b64 v{{[0-9]+}}, v{{\[[0-9]+:[0-9]+\]}}, v{{\[[0-9]+:[0-9]+\]}} offset1:1
544 define amdgpu_kernel void @local_zextload_v64i16_to_v64i32(<64 x i32> addrspace(3)* %out, <64 x i16> addrspace(3)* %in) #0 {
545 %load = load <64 x i16>, <64 x i16> addrspace(3)* %in
546 %ext = zext <64 x i16> %load to <64 x i32>
547 store <64 x i32> %ext, <64 x i32> addrspace(3)* %out
551 ; FUNC-LABEL: {{^}}local_sextload_v64i16_to_v64i32:
553 ; SICIVI: s_mov_b32 m0
587 define amdgpu_kernel void @local_sextload_v64i16_to_v64i32(<64 x i32> addrspace(3)* %out, <64 x i16> addrspace(3)* %in) #0 {
588 %load = load <64 x i16>, <64 x i16> addrspace(3)* %in
589 %ext = sext <64 x i16> %load to <64 x i32>
590 store <64 x i32> %ext, <64 x i32> addrspace(3)* %out
594 ; FUNC-LABEL: {{^}}local_zextload_i16_to_i64:
596 ; SICIVI: s_mov_b32 m0
598 ; GCN-DAG: ds_read_u16 v[[LO:[0-9]+]],
599 ; GCN-DAG: v_mov_b32_e32 v[[HI:[0-9]+]], 0{{$}}
601 ; GCN: ds_write_b64 v{{[0-9]+}}, v{{\[}}[[LO]]:[[HI]]]
603 ; EG: MOV {{[* ]*}}[[FROM:T[0-9]+\.[XYZW]]], KC0[2].Z
604 ; EG: LDS_USHORT_READ_RET {{.*}} [[FROM]]
605 ; EG-DAG: MOV {{[* ]*}}[[DATA:T[0-9]+\.[XYZW]]], OQAP
606 ; EG-DAG: MOV {{[* ]*}}[[TO:T[0-9]+\.[XYZW]]], KC0[2].Y
608 define amdgpu_kernel void @local_zextload_i16_to_i64(i64 addrspace(3)* %out, i16 addrspace(3)* %in) #0 {
609 %a = load i16, i16 addrspace(3)* %in
610 %ext = zext i16 %a to i64
611 store i64 %ext, i64 addrspace(3)* %out
615 ; FUNC-LABEL: {{^}}local_sextload_i16_to_i64:
617 ; SICIVI: s_mov_b32 m0
619 ; FIXME: Need to optimize this sequence to avoid an extra shift.
620 ; t25: i32,ch = load<LD2[%in(addrspace=3)], anyext from i16> t12, t10, undef:i32
621 ; t28: i64 = any_extend t25
622 ; t30: i64 = sign_extend_inreg t28, ValueType:ch:i16
623 ; SI: ds_read_i16 v[[LO:[0-9]+]],
624 ; GFX89: ds_read_u16 v[[ULO:[0-9]+]]
625 ; GFX89: v_bfe_i32 v[[LO:[0-9]+]], v[[ULO]], 0, 16
626 ; GCN-DAG: v_ashrrev_i32_e32 v[[HI:[0-9]+]], 31, v[[LO]]
628 ; GCN: ds_write_b64 v{{[0-9]+}}, v{{\[}}[[LO]]:[[HI]]]
630 ; EG: MOV {{[* ]*}}[[FROM:T[0-9]+\.[XYZW]]], KC0[2].Z
631 ; EG: LDS_USHORT_READ_RET {{.*}} [[FROM]]
632 ; EG-DAG: MOV {{[* ]*}}[[TMP:T[0-9]+\.[XYZW]]], OQAP
633 ; EG-DAG: MOV {{[* ]*}}[[TO:T[0-9]+\.[XYZW]]], KC0[2].Y
634 ; EG-DAG: BFE_INT {{[* ]*}}[[DATA:T[0-9]+\.[XYZW]]], {{.*}}, 0.0, literal
637 ; EG: LDS_WRITE {{\*?}} [[TO]], [[DATA]]
638 define amdgpu_kernel void @local_sextload_i16_to_i64(i64 addrspace(3)* %out, i16 addrspace(3)* %in) #0 {
639 %a = load i16, i16 addrspace(3)* %in
640 %ext = sext i16 %a to i64
641 store i64 %ext, i64 addrspace(3)* %out
645 ; FUNC-LABEL: {{^}}local_zextload_v1i16_to_v1i64:
647 ; SICIVI: s_mov_b32 m0
650 ; EG: MOV {{[* ]*}}[[FROM:T[0-9]+\.[XYZW]]], KC0[2].Z
651 ; EG: LDS_USHORT_READ_RET {{.*}} [[FROM]]
652 ; EG-DAG: MOV {{[* ]*}}[[DATA:T[0-9]+\.[XYZW]]], OQAP
653 ; EG-DAG: MOV {{[* ]*}}[[TO:T[0-9]+\.[XYZW]]], KC0[2].Y
655 define amdgpu_kernel void @local_zextload_v1i16_to_v1i64(<1 x i64> addrspace(3)* %out, <1 x i16> addrspace(3)* %in) #0 {
656 %load = load <1 x i16>, <1 x i16> addrspace(3)* %in
657 %ext = zext <1 x i16> %load to <1 x i64>
658 store <1 x i64> %ext, <1 x i64> addrspace(3)* %out
662 ; FUNC-LABEL: {{^}}local_sextload_v1i16_to_v1i64:
664 ; SICIVI: s_mov_b32 m0
667 ; EG: MOV {{[* ]*}}[[FROM:T[0-9]+\.[XYZW]]], KC0[2].Z
668 ; EG: LDS_USHORT_READ_RET {{.*}} [[FROM]]
669 ; EG-DAG: MOV {{[* ]*}}[[TMP:T[0-9]+\.[XYZW]]], OQAP
670 ; EG-DAG: MOV {{[* ]*}}[[TO:T[0-9]+\.[XYZW]]], KC0[2].Y
671 ; EG-DAG: BFE_INT {{[* ]*}}[[DATA:T[0-9]+\.[XYZW]]], {{.*}}, 0.0, literal
674 ; EG: LDS_WRITE {{\*?}} [[TO]], [[DATA]]
675 define amdgpu_kernel void @local_sextload_v1i16_to_v1i64(<1 x i64> addrspace(3)* %out, <1 x i16> addrspace(3)* %in) #0 {
676 %load = load <1 x i16>, <1 x i16> addrspace(3)* %in
677 %ext = sext <1 x i16> %load to <1 x i64>
678 store <1 x i64> %ext, <1 x i64> addrspace(3)* %out
682 ; FUNC-LABEL: {{^}}local_zextload_v2i16_to_v2i64:
684 ; SICIVI: s_mov_b32 m0
688 define amdgpu_kernel void @local_zextload_v2i16_to_v2i64(<2 x i64> addrspace(3)* %out, <2 x i16> addrspace(3)* %in) #0 {
689 %load = load <2 x i16>, <2 x i16> addrspace(3)* %in
690 %ext = zext <2 x i16> %load to <2 x i64>
691 store <2 x i64> %ext, <2 x i64> addrspace(3)* %out
695 ; FUNC-LABEL: {{^}}local_sextload_v2i16_to_v2i64:
697 ; SICIVI: s_mov_b32 m0
703 define amdgpu_kernel void @local_sextload_v2i16_to_v2i64(<2 x i64> addrspace(3)* %out, <2 x i16> addrspace(3)* %in) #0 {
704 %load = load <2 x i16>, <2 x i16> addrspace(3)* %in
705 %ext = sext <2 x i16> %load to <2 x i64>
706 store <2 x i64> %ext, <2 x i64> addrspace(3)* %out
710 ; FUNC-LABEL: {{^}}local_zextload_v4i16_to_v4i64:
712 ; SICIVI: s_mov_b32 m0
717 define amdgpu_kernel void @local_zextload_v4i16_to_v4i64(<4 x i64> addrspace(3)* %out, <4 x i16> addrspace(3)* %in) #0 {
718 %load = load <4 x i16>, <4 x i16> addrspace(3)* %in
719 %ext = zext <4 x i16> %load to <4 x i64>
720 store <4 x i64> %ext, <4 x i64> addrspace(3)* %out
724 ; FUNC-LABEL: {{^}}local_sextload_v4i16_to_v4i64:
726 ; SICIVI: s_mov_b32 m0
735 define amdgpu_kernel void @local_sextload_v4i16_to_v4i64(<4 x i64> addrspace(3)* %out, <4 x i16> addrspace(3)* %in) #0 {
736 %load = load <4 x i16>, <4 x i16> addrspace(3)* %in
737 %ext = sext <4 x i16> %load to <4 x i64>
738 store <4 x i64> %ext, <4 x i64> addrspace(3)* %out
742 ; FUNC-LABEL: {{^}}local_zextload_v8i16_to_v8i64:
744 ; SICIVI: s_mov_b32 m0
751 define amdgpu_kernel void @local_zextload_v8i16_to_v8i64(<8 x i64> addrspace(3)* %out, <8 x i16> addrspace(3)* %in) #0 {
752 %load = load <8 x i16>, <8 x i16> addrspace(3)* %in
753 %ext = zext <8 x i16> %load to <8 x i64>
754 store <8 x i64> %ext, <8 x i64> addrspace(3)* %out
758 ; FUNC-LABEL: {{^}}local_sextload_v8i16_to_v8i64:
760 ; SICIVI: s_mov_b32 m0
775 define amdgpu_kernel void @local_sextload_v8i16_to_v8i64(<8 x i64> addrspace(3)* %out, <8 x i16> addrspace(3)* %in) #0 {
776 %load = load <8 x i16>, <8 x i16> addrspace(3)* %in
777 %ext = sext <8 x i16> %load to <8 x i64>
778 store <8 x i64> %ext, <8 x i64> addrspace(3)* %out
782 ; FUNC-LABEL: {{^}}local_zextload_v16i16_to_v16i64:
784 ; SICIVI: s_mov_b32 m0
795 define amdgpu_kernel void @local_zextload_v16i16_to_v16i64(<16 x i64> addrspace(3)* %out, <16 x i16> addrspace(3)* %in) #0 {
796 %load = load <16 x i16>, <16 x i16> addrspace(3)* %in
797 %ext = zext <16 x i16> %load to <16 x i64>
798 store <16 x i64> %ext, <16 x i64> addrspace(3)* %out
802 ; FUNC-LABEL: {{^}}local_sextload_v16i16_to_v16i64:
804 ; SICIVI: s_mov_b32 m0
831 define amdgpu_kernel void @local_sextload_v16i16_to_v16i64(<16 x i64> addrspace(3)* %out, <16 x i16> addrspace(3)* %in) #0 {
832 %load = load <16 x i16>, <16 x i16> addrspace(3)* %in
833 %ext = sext <16 x i16> %load to <16 x i64>
834 store <16 x i64> %ext, <16 x i64> addrspace(3)* %out
838 ; FUNC-LABEL: {{^}}local_zextload_v32i16_to_v32i64:
840 ; SICIVI: s_mov_b32 m0
859 define amdgpu_kernel void @local_zextload_v32i16_to_v32i64(<32 x i64> addrspace(3)* %out, <32 x i16> addrspace(3)* %in) #0 {
860 %load = load <32 x i16>, <32 x i16> addrspace(3)* %in
861 %ext = zext <32 x i16> %load to <32 x i64>
862 store <32 x i64> %ext, <32 x i64> addrspace(3)* %out
866 ; FUNC-LABEL: {{^}}local_sextload_v32i16_to_v32i64:
868 ; SICIVI: s_mov_b32 m0
919 define amdgpu_kernel void @local_sextload_v32i16_to_v32i64(<32 x i64> addrspace(3)* %out, <32 x i16> addrspace(3)* %in) #0 {
920 %load = load <32 x i16>, <32 x i16> addrspace(3)* %in
921 %ext = sext <32 x i16> %load to <32 x i64>
922 store <32 x i64> %ext, <32 x i64> addrspace(3)* %out
926 ; ; XFUNC-LABEL: {{^}}local_zextload_v64i16_to_v64i64:
927 ; define amdgpu_kernel void @local_zextload_v64i16_to_v64i64(<64 x i64> addrspace(3)* %out, <64 x i16> addrspace(3)* %in) #0 {
928 ; %load = load <64 x i16>, <64 x i16> addrspace(3)* %in
929 ; %ext = zext <64 x i16> %load to <64 x i64>
930 ; store <64 x i64> %ext, <64 x i64> addrspace(3)* %out
934 ; ; XFUNC-LABEL: {{^}}local_sextload_v64i16_to_v64i64:
935 ; define amdgpu_kernel void @local_sextload_v64i16_to_v64i64(<64 x i64> addrspace(3)* %out, <64 x i16> addrspace(3)* %in) #0 {
936 ; %load = load <64 x i16>, <64 x i16> addrspace(3)* %in
937 ; %ext = sext <64 x i16> %load to <64 x i64>
938 ; store <64 x i64> %ext, <64 x i64> addrspace(3)* %out
942 ; Tests if ds_read/write_b128 gets generated for the 16 byte aligned load.
943 ; FUNC-LABEL: {{^}}local_v8i16_to_128:
945 ; SI-NOT: ds_read_b128
946 ; SI-NOT: ds_write_b128
949 ; CIVI: ds_write_b128
955 define amdgpu_kernel void @local_v8i16_to_128(<8 x i16> addrspace(3)* %out, <8 x i16> addrspace(3)* %in) {
956 %ld = load <8 x i16>, <8 x i16> addrspace(3)* %in, align 16
957 store <8 x i16> %ld, <8 x i16> addrspace(3)* %out, align 16
961 attributes #0 = { nounwind }