xref: /aosp_15_r20/external/llvm/test/CodeGen/AMDGPU/load-local-i1.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc -march=amdgcn -verify-machineinstrs < %s | FileCheck -check-prefix=GCN -check-prefix=FUNC %s
2*9880d681SAndroid Build Coastguard Worker; RUN: llc -march=amdgcn -mcpu=tonga -verify-machineinstrs < %s | FileCheck -check-prefix=GCN -check-prefix=FUNC %s
3*9880d681SAndroid Build Coastguard Worker; RUN: llc -march=r600 -mcpu=cypress < %s | FileCheck -check-prefix=EG -check-prefix=FUNC %s
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_load_i1:
6*9880d681SAndroid Build Coastguard Worker; GCN: ds_read_u8
7*9880d681SAndroid Build Coastguard Worker; GCN: v_and_b32_e32 v{{[0-9]+}}, 1
8*9880d681SAndroid Build Coastguard Worker; GCN: ds_write_b8
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Worker; EG: LDS_UBYTE_READ_RET
11*9880d681SAndroid Build Coastguard Worker; EG: AND_INT
12*9880d681SAndroid Build Coastguard Worker; EG: LDS_BYTE_WRITE
13*9880d681SAndroid Build Coastguard Workerdefine void @local_load_i1(i1 addrspace(3)* %out, i1 addrspace(3)* %in) #0 {
14*9880d681SAndroid Build Coastguard Worker  %load = load i1, i1 addrspace(3)* %in
15*9880d681SAndroid Build Coastguard Worker  store i1 %load, i1 addrspace(3)* %out
16*9880d681SAndroid Build Coastguard Worker  ret void
17*9880d681SAndroid Build Coastguard Worker}
18*9880d681SAndroid Build Coastguard Worker
19*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_load_v2i1:
20*9880d681SAndroid Build Coastguard Workerdefine void @local_load_v2i1(<2 x i1> addrspace(3)* %out, <2 x i1> addrspace(3)* %in) #0 {
21*9880d681SAndroid Build Coastguard Worker  %load = load <2 x i1>, <2 x i1> addrspace(3)* %in
22*9880d681SAndroid Build Coastguard Worker  store <2 x i1> %load, <2 x i1> addrspace(3)* %out
23*9880d681SAndroid Build Coastguard Worker  ret void
24*9880d681SAndroid Build Coastguard Worker}
25*9880d681SAndroid Build Coastguard Worker
26*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_load_v3i1:
27*9880d681SAndroid Build Coastguard Workerdefine void @local_load_v3i1(<3 x i1> addrspace(3)* %out, <3 x i1> addrspace(3)* %in) #0 {
28*9880d681SAndroid Build Coastguard Worker  %load = load <3 x i1>, <3 x i1> addrspace(3)* %in
29*9880d681SAndroid Build Coastguard Worker  store <3 x i1> %load, <3 x i1> addrspace(3)* %out
30*9880d681SAndroid Build Coastguard Worker  ret void
31*9880d681SAndroid Build Coastguard Worker}
32*9880d681SAndroid Build Coastguard Worker
33*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_load_v4i1:
34*9880d681SAndroid Build Coastguard Workerdefine void @local_load_v4i1(<4 x i1> addrspace(3)* %out, <4 x i1> addrspace(3)* %in) #0 {
35*9880d681SAndroid Build Coastguard Worker  %load = load <4 x i1>, <4 x i1> addrspace(3)* %in
36*9880d681SAndroid Build Coastguard Worker  store <4 x i1> %load, <4 x i1> addrspace(3)* %out
37*9880d681SAndroid Build Coastguard Worker  ret void
38*9880d681SAndroid Build Coastguard Worker}
39*9880d681SAndroid Build Coastguard Worker
40*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_load_v8i1:
41*9880d681SAndroid Build Coastguard Workerdefine void @local_load_v8i1(<8 x i1> addrspace(3)* %out, <8 x i1> addrspace(3)* %in) #0 {
42*9880d681SAndroid Build Coastguard Worker  %load = load <8 x i1>, <8 x i1> addrspace(3)* %in
43*9880d681SAndroid Build Coastguard Worker  store <8 x i1> %load, <8 x i1> addrspace(3)* %out
44*9880d681SAndroid Build Coastguard Worker  ret void
45*9880d681SAndroid Build Coastguard Worker}
46*9880d681SAndroid Build Coastguard Worker
47*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_load_v16i1:
48*9880d681SAndroid Build Coastguard Workerdefine void @local_load_v16i1(<16 x i1> addrspace(3)* %out, <16 x i1> addrspace(3)* %in) #0 {
49*9880d681SAndroid Build Coastguard Worker  %load = load <16 x i1>, <16 x i1> addrspace(3)* %in
50*9880d681SAndroid Build Coastguard Worker  store <16 x i1> %load, <16 x i1> addrspace(3)* %out
51*9880d681SAndroid Build Coastguard Worker  ret void
52*9880d681SAndroid Build Coastguard Worker}
53*9880d681SAndroid Build Coastguard Worker
54*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_load_v32i1:
55*9880d681SAndroid Build Coastguard Workerdefine void @local_load_v32i1(<32 x i1> addrspace(3)* %out, <32 x i1> addrspace(3)* %in) #0 {
56*9880d681SAndroid Build Coastguard Worker  %load = load <32 x i1>, <32 x i1> addrspace(3)* %in
57*9880d681SAndroid Build Coastguard Worker  store <32 x i1> %load, <32 x i1> addrspace(3)* %out
58*9880d681SAndroid Build Coastguard Worker  ret void
59*9880d681SAndroid Build Coastguard Worker}
60*9880d681SAndroid Build Coastguard Worker
61*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_load_v64i1:
62*9880d681SAndroid Build Coastguard Workerdefine void @local_load_v64i1(<64 x i1> addrspace(3)* %out, <64 x i1> addrspace(3)* %in) #0 {
63*9880d681SAndroid Build Coastguard Worker  %load = load <64 x i1>, <64 x i1> addrspace(3)* %in
64*9880d681SAndroid Build Coastguard Worker  store <64 x i1> %load, <64 x i1> addrspace(3)* %out
65*9880d681SAndroid Build Coastguard Worker  ret void
66*9880d681SAndroid Build Coastguard Worker}
67*9880d681SAndroid Build Coastguard Worker
68*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_zextload_i1_to_i32:
69*9880d681SAndroid Build Coastguard Worker; GCN: ds_read_u8
70*9880d681SAndroid Build Coastguard Worker; GCN: ds_write_b32
71*9880d681SAndroid Build Coastguard Workerdefine void @local_zextload_i1_to_i32(i32 addrspace(3)* %out, i1 addrspace(3)* %in) #0 {
72*9880d681SAndroid Build Coastguard Worker  %a = load i1, i1 addrspace(3)* %in
73*9880d681SAndroid Build Coastguard Worker  %ext = zext i1 %a to i32
74*9880d681SAndroid Build Coastguard Worker  store i32 %ext, i32 addrspace(3)* %out
75*9880d681SAndroid Build Coastguard Worker  ret void
76*9880d681SAndroid Build Coastguard Worker}
77*9880d681SAndroid Build Coastguard Worker
78*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_sextload_i1_to_i32:
79*9880d681SAndroid Build Coastguard Worker; GCN: ds_read_u8
80*9880d681SAndroid Build Coastguard Worker; GCN: v_bfe_i32 {{v[0-9]+}}, {{v[0-9]+}}, 0, 1{{$}}
81*9880d681SAndroid Build Coastguard Worker; GCN: ds_write_b32
82*9880d681SAndroid Build Coastguard Worker
83*9880d681SAndroid Build Coastguard Worker; EG: LDS_UBYTE_READ_RET
84*9880d681SAndroid Build Coastguard Worker; EG: BFE_INT
85*9880d681SAndroid Build Coastguard Workerdefine void @local_sextload_i1_to_i32(i32 addrspace(3)* %out, i1 addrspace(3)* %in) #0 {
86*9880d681SAndroid Build Coastguard Worker  %a = load i1, i1 addrspace(3)* %in
87*9880d681SAndroid Build Coastguard Worker  %ext = sext i1 %a to i32
88*9880d681SAndroid Build Coastguard Worker  store i32 %ext, i32 addrspace(3)* %out
89*9880d681SAndroid Build Coastguard Worker  ret void
90*9880d681SAndroid Build Coastguard Worker}
91*9880d681SAndroid Build Coastguard Worker
92*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_zextload_v1i1_to_v1i32:
93*9880d681SAndroid Build Coastguard Workerdefine void @local_zextload_v1i1_to_v1i32(<1 x i32> addrspace(3)* %out, <1 x i1> addrspace(3)* %in) #0 {
94*9880d681SAndroid Build Coastguard Worker  %load = load <1 x i1>, <1 x i1> addrspace(3)* %in
95*9880d681SAndroid Build Coastguard Worker  %ext = zext <1 x i1> %load to <1 x i32>
96*9880d681SAndroid Build Coastguard Worker  store <1 x i32> %ext, <1 x i32> addrspace(3)* %out
97*9880d681SAndroid Build Coastguard Worker  ret void
98*9880d681SAndroid Build Coastguard Worker}
99*9880d681SAndroid Build Coastguard Worker
100*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_sextload_v1i1_to_v1i32:
101*9880d681SAndroid Build Coastguard Workerdefine void @local_sextload_v1i1_to_v1i32(<1 x i32> addrspace(3)* %out, <1 x i1> addrspace(3)* %in) #0 {
102*9880d681SAndroid Build Coastguard Worker  %load = load <1 x i1>, <1 x i1> addrspace(3)* %in
103*9880d681SAndroid Build Coastguard Worker  %ext = sext <1 x i1> %load to <1 x i32>
104*9880d681SAndroid Build Coastguard Worker  store <1 x i32> %ext, <1 x i32> addrspace(3)* %out
105*9880d681SAndroid Build Coastguard Worker  ret void
106*9880d681SAndroid Build Coastguard Worker}
107*9880d681SAndroid Build Coastguard Worker
108*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_zextload_v2i1_to_v2i32:
109*9880d681SAndroid Build Coastguard Workerdefine void @local_zextload_v2i1_to_v2i32(<2 x i32> addrspace(3)* %out, <2 x i1> addrspace(3)* %in) #0 {
110*9880d681SAndroid Build Coastguard Worker  %load = load <2 x i1>, <2 x i1> addrspace(3)* %in
111*9880d681SAndroid Build Coastguard Worker  %ext = zext <2 x i1> %load to <2 x i32>
112*9880d681SAndroid Build Coastguard Worker  store <2 x i32> %ext, <2 x i32> addrspace(3)* %out
113*9880d681SAndroid Build Coastguard Worker  ret void
114*9880d681SAndroid Build Coastguard Worker}
115*9880d681SAndroid Build Coastguard Worker
116*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_sextload_v2i1_to_v2i32:
117*9880d681SAndroid Build Coastguard Workerdefine void @local_sextload_v2i1_to_v2i32(<2 x i32> addrspace(3)* %out, <2 x i1> addrspace(3)* %in) #0 {
118*9880d681SAndroid Build Coastguard Worker  %load = load <2 x i1>, <2 x i1> addrspace(3)* %in
119*9880d681SAndroid Build Coastguard Worker  %ext = sext <2 x i1> %load to <2 x i32>
120*9880d681SAndroid Build Coastguard Worker  store <2 x i32> %ext, <2 x i32> addrspace(3)* %out
121*9880d681SAndroid Build Coastguard Worker  ret void
122*9880d681SAndroid Build Coastguard Worker}
123*9880d681SAndroid Build Coastguard Worker
124*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_zextload_v3i1_to_v3i32:
125*9880d681SAndroid Build Coastguard Workerdefine void @local_zextload_v3i1_to_v3i32(<3 x i32> addrspace(3)* %out, <3 x i1> addrspace(3)* %in) #0 {
126*9880d681SAndroid Build Coastguard Worker  %load = load <3 x i1>, <3 x i1> addrspace(3)* %in
127*9880d681SAndroid Build Coastguard Worker  %ext = zext <3 x i1> %load to <3 x i32>
128*9880d681SAndroid Build Coastguard Worker  store <3 x i32> %ext, <3 x i32> addrspace(3)* %out
129*9880d681SAndroid Build Coastguard Worker  ret void
130*9880d681SAndroid Build Coastguard Worker}
131*9880d681SAndroid Build Coastguard Worker
132*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_sextload_v3i1_to_v3i32:
133*9880d681SAndroid Build Coastguard Workerdefine void @local_sextload_v3i1_to_v3i32(<3 x i32> addrspace(3)* %out, <3 x i1> addrspace(3)* %in) #0 {
134*9880d681SAndroid Build Coastguard Worker  %load = load <3 x i1>, <3 x i1> addrspace(3)* %in
135*9880d681SAndroid Build Coastguard Worker  %ext = sext <3 x i1> %load to <3 x i32>
136*9880d681SAndroid Build Coastguard Worker  store <3 x i32> %ext, <3 x i32> addrspace(3)* %out
137*9880d681SAndroid Build Coastguard Worker  ret void
138*9880d681SAndroid Build Coastguard Worker}
139*9880d681SAndroid Build Coastguard Worker
140*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_zextload_v4i1_to_v4i32:
141*9880d681SAndroid Build Coastguard Workerdefine void @local_zextload_v4i1_to_v4i32(<4 x i32> addrspace(3)* %out, <4 x i1> addrspace(3)* %in) #0 {
142*9880d681SAndroid Build Coastguard Worker  %load = load <4 x i1>, <4 x i1> addrspace(3)* %in
143*9880d681SAndroid Build Coastguard Worker  %ext = zext <4 x i1> %load to <4 x i32>
144*9880d681SAndroid Build Coastguard Worker  store <4 x i32> %ext, <4 x i32> addrspace(3)* %out
145*9880d681SAndroid Build Coastguard Worker  ret void
146*9880d681SAndroid Build Coastguard Worker}
147*9880d681SAndroid Build Coastguard Worker
148*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_sextload_v4i1_to_v4i32:
149*9880d681SAndroid Build Coastguard Workerdefine void @local_sextload_v4i1_to_v4i32(<4 x i32> addrspace(3)* %out, <4 x i1> addrspace(3)* %in) #0 {
150*9880d681SAndroid Build Coastguard Worker  %load = load <4 x i1>, <4 x i1> addrspace(3)* %in
151*9880d681SAndroid Build Coastguard Worker  %ext = sext <4 x i1> %load to <4 x i32>
152*9880d681SAndroid Build Coastguard Worker  store <4 x i32> %ext, <4 x i32> addrspace(3)* %out
153*9880d681SAndroid Build Coastguard Worker  ret void
154*9880d681SAndroid Build Coastguard Worker}
155*9880d681SAndroid Build Coastguard Worker
156*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_zextload_v8i1_to_v8i32:
157*9880d681SAndroid Build Coastguard Workerdefine void @local_zextload_v8i1_to_v8i32(<8 x i32> addrspace(3)* %out, <8 x i1> addrspace(3)* %in) #0 {
158*9880d681SAndroid Build Coastguard Worker  %load = load <8 x i1>, <8 x i1> addrspace(3)* %in
159*9880d681SAndroid Build Coastguard Worker  %ext = zext <8 x i1> %load to <8 x i32>
160*9880d681SAndroid Build Coastguard Worker  store <8 x i32> %ext, <8 x i32> addrspace(3)* %out
161*9880d681SAndroid Build Coastguard Worker  ret void
162*9880d681SAndroid Build Coastguard Worker}
163*9880d681SAndroid Build Coastguard Worker
164*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_sextload_v8i1_to_v8i32:
165*9880d681SAndroid Build Coastguard Workerdefine void @local_sextload_v8i1_to_v8i32(<8 x i32> addrspace(3)* %out, <8 x i1> addrspace(3)* %in) #0 {
166*9880d681SAndroid Build Coastguard Worker  %load = load <8 x i1>, <8 x i1> addrspace(3)* %in
167*9880d681SAndroid Build Coastguard Worker  %ext = sext <8 x i1> %load to <8 x i32>
168*9880d681SAndroid Build Coastguard Worker  store <8 x i32> %ext, <8 x i32> addrspace(3)* %out
169*9880d681SAndroid Build Coastguard Worker  ret void
170*9880d681SAndroid Build Coastguard Worker}
171*9880d681SAndroid Build Coastguard Worker
172*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_zextload_v16i1_to_v16i32:
173*9880d681SAndroid Build Coastguard Workerdefine void @local_zextload_v16i1_to_v16i32(<16 x i32> addrspace(3)* %out, <16 x i1> addrspace(3)* %in) #0 {
174*9880d681SAndroid Build Coastguard Worker  %load = load <16 x i1>, <16 x i1> addrspace(3)* %in
175*9880d681SAndroid Build Coastguard Worker  %ext = zext <16 x i1> %load to <16 x i32>
176*9880d681SAndroid Build Coastguard Worker  store <16 x i32> %ext, <16 x i32> addrspace(3)* %out
177*9880d681SAndroid Build Coastguard Worker  ret void
178*9880d681SAndroid Build Coastguard Worker}
179*9880d681SAndroid Build Coastguard Worker
180*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_sextload_v16i1_to_v16i32:
181*9880d681SAndroid Build Coastguard Workerdefine void @local_sextload_v16i1_to_v16i32(<16 x i32> addrspace(3)* %out, <16 x i1> addrspace(3)* %in) #0 {
182*9880d681SAndroid Build Coastguard Worker  %load = load <16 x i1>, <16 x i1> addrspace(3)* %in
183*9880d681SAndroid Build Coastguard Worker  %ext = sext <16 x i1> %load to <16 x i32>
184*9880d681SAndroid Build Coastguard Worker  store <16 x i32> %ext, <16 x i32> addrspace(3)* %out
185*9880d681SAndroid Build Coastguard Worker  ret void
186*9880d681SAndroid Build Coastguard Worker}
187*9880d681SAndroid Build Coastguard Worker
188*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_zextload_v32i1_to_v32i32:
189*9880d681SAndroid Build Coastguard Workerdefine void @local_zextload_v32i1_to_v32i32(<32 x i32> addrspace(3)* %out, <32 x i1> addrspace(3)* %in) #0 {
190*9880d681SAndroid Build Coastguard Worker  %load = load <32 x i1>, <32 x i1> addrspace(3)* %in
191*9880d681SAndroid Build Coastguard Worker  %ext = zext <32 x i1> %load to <32 x i32>
192*9880d681SAndroid Build Coastguard Worker  store <32 x i32> %ext, <32 x i32> addrspace(3)* %out
193*9880d681SAndroid Build Coastguard Worker  ret void
194*9880d681SAndroid Build Coastguard Worker}
195*9880d681SAndroid Build Coastguard Worker
196*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_sextload_v32i1_to_v32i32:
197*9880d681SAndroid Build Coastguard Workerdefine void @local_sextload_v32i1_to_v32i32(<32 x i32> addrspace(3)* %out, <32 x i1> addrspace(3)* %in) #0 {
198*9880d681SAndroid Build Coastguard Worker  %load = load <32 x i1>, <32 x i1> addrspace(3)* %in
199*9880d681SAndroid Build Coastguard Worker  %ext = sext <32 x i1> %load to <32 x i32>
200*9880d681SAndroid Build Coastguard Worker  store <32 x i32> %ext, <32 x i32> addrspace(3)* %out
201*9880d681SAndroid Build Coastguard Worker  ret void
202*9880d681SAndroid Build Coastguard Worker}
203*9880d681SAndroid Build Coastguard Worker
204*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_zextload_v64i1_to_v64i32:
205*9880d681SAndroid Build Coastguard Workerdefine void @local_zextload_v64i1_to_v64i32(<64 x i32> addrspace(3)* %out, <64 x i1> addrspace(3)* %in) #0 {
206*9880d681SAndroid Build Coastguard Worker  %load = load <64 x i1>, <64 x i1> addrspace(3)* %in
207*9880d681SAndroid Build Coastguard Worker  %ext = zext <64 x i1> %load to <64 x i32>
208*9880d681SAndroid Build Coastguard Worker  store <64 x i32> %ext, <64 x i32> addrspace(3)* %out
209*9880d681SAndroid Build Coastguard Worker  ret void
210*9880d681SAndroid Build Coastguard Worker}
211*9880d681SAndroid Build Coastguard Worker
212*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_sextload_v64i1_to_v64i32:
213*9880d681SAndroid Build Coastguard Workerdefine void @local_sextload_v64i1_to_v64i32(<64 x i32> addrspace(3)* %out, <64 x i1> addrspace(3)* %in) #0 {
214*9880d681SAndroid Build Coastguard Worker  %load = load <64 x i1>, <64 x i1> addrspace(3)* %in
215*9880d681SAndroid Build Coastguard Worker  %ext = sext <64 x i1> %load to <64 x i32>
216*9880d681SAndroid Build Coastguard Worker  store <64 x i32> %ext, <64 x i32> addrspace(3)* %out
217*9880d681SAndroid Build Coastguard Worker  ret void
218*9880d681SAndroid Build Coastguard Worker}
219*9880d681SAndroid Build Coastguard Worker
220*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_zextload_i1_to_i64:
221*9880d681SAndroid Build Coastguard Worker; GCN-DAG: ds_read_u8 [[LOAD:v[0-9]+]],
222*9880d681SAndroid Build Coastguard Worker; GCN-DAG: v_mov_b32_e32 {{v[0-9]+}}, 0{{$}}
223*9880d681SAndroid Build Coastguard Worker; GCN: ds_write_b64
224*9880d681SAndroid Build Coastguard Workerdefine void @local_zextload_i1_to_i64(i64 addrspace(3)* %out, i1 addrspace(3)* %in) #0 {
225*9880d681SAndroid Build Coastguard Worker  %a = load i1, i1 addrspace(3)* %in
226*9880d681SAndroid Build Coastguard Worker  %ext = zext i1 %a to i64
227*9880d681SAndroid Build Coastguard Worker  store i64 %ext, i64 addrspace(3)* %out
228*9880d681SAndroid Build Coastguard Worker  ret void
229*9880d681SAndroid Build Coastguard Worker}
230*9880d681SAndroid Build Coastguard Worker
231*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_sextload_i1_to_i64:
232*9880d681SAndroid Build Coastguard Worker; GCN: ds_read_u8 [[LOAD:v[0-9]+]],
233*9880d681SAndroid Build Coastguard Worker; GCN: v_bfe_i32 [[BFE:v[0-9]+]], {{v[0-9]+}}, 0, 1{{$}}
234*9880d681SAndroid Build Coastguard Worker; GCN: v_ashrrev_i32_e32 v{{[0-9]+}}, 31, [[BFE]]
235*9880d681SAndroid Build Coastguard Worker; GCN: ds_write_b64
236*9880d681SAndroid Build Coastguard Workerdefine void @local_sextload_i1_to_i64(i64 addrspace(3)* %out, i1 addrspace(3)* %in) #0 {
237*9880d681SAndroid Build Coastguard Worker  %a = load i1, i1 addrspace(3)* %in
238*9880d681SAndroid Build Coastguard Worker  %ext = sext i1 %a to i64
239*9880d681SAndroid Build Coastguard Worker  store i64 %ext, i64 addrspace(3)* %out
240*9880d681SAndroid Build Coastguard Worker  ret void
241*9880d681SAndroid Build Coastguard Worker}
242*9880d681SAndroid Build Coastguard Worker
243*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_zextload_v1i1_to_v1i64:
244*9880d681SAndroid Build Coastguard Workerdefine void @local_zextload_v1i1_to_v1i64(<1 x i64> addrspace(3)* %out, <1 x i1> addrspace(3)* %in) #0 {
245*9880d681SAndroid Build Coastguard Worker  %load = load <1 x i1>, <1 x i1> addrspace(3)* %in
246*9880d681SAndroid Build Coastguard Worker  %ext = zext <1 x i1> %load to <1 x i64>
247*9880d681SAndroid Build Coastguard Worker  store <1 x i64> %ext, <1 x i64> addrspace(3)* %out
248*9880d681SAndroid Build Coastguard Worker  ret void
249*9880d681SAndroid Build Coastguard Worker}
250*9880d681SAndroid Build Coastguard Worker
251*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_sextload_v1i1_to_v1i64:
252*9880d681SAndroid Build Coastguard Workerdefine void @local_sextload_v1i1_to_v1i64(<1 x i64> addrspace(3)* %out, <1 x i1> addrspace(3)* %in) #0 {
253*9880d681SAndroid Build Coastguard Worker  %load = load <1 x i1>, <1 x i1> addrspace(3)* %in
254*9880d681SAndroid Build Coastguard Worker  %ext = sext <1 x i1> %load to <1 x i64>
255*9880d681SAndroid Build Coastguard Worker  store <1 x i64> %ext, <1 x i64> addrspace(3)* %out
256*9880d681SAndroid Build Coastguard Worker  ret void
257*9880d681SAndroid Build Coastguard Worker}
258*9880d681SAndroid Build Coastguard Worker
259*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_zextload_v2i1_to_v2i64:
260*9880d681SAndroid Build Coastguard Workerdefine void @local_zextload_v2i1_to_v2i64(<2 x i64> addrspace(3)* %out, <2 x i1> addrspace(3)* %in) #0 {
261*9880d681SAndroid Build Coastguard Worker  %load = load <2 x i1>, <2 x i1> addrspace(3)* %in
262*9880d681SAndroid Build Coastguard Worker  %ext = zext <2 x i1> %load to <2 x i64>
263*9880d681SAndroid Build Coastguard Worker  store <2 x i64> %ext, <2 x i64> addrspace(3)* %out
264*9880d681SAndroid Build Coastguard Worker  ret void
265*9880d681SAndroid Build Coastguard Worker}
266*9880d681SAndroid Build Coastguard Worker
267*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_sextload_v2i1_to_v2i64:
268*9880d681SAndroid Build Coastguard Workerdefine void @local_sextload_v2i1_to_v2i64(<2 x i64> addrspace(3)* %out, <2 x i1> addrspace(3)* %in) #0 {
269*9880d681SAndroid Build Coastguard Worker  %load = load <2 x i1>, <2 x i1> addrspace(3)* %in
270*9880d681SAndroid Build Coastguard Worker  %ext = sext <2 x i1> %load to <2 x i64>
271*9880d681SAndroid Build Coastguard Worker  store <2 x i64> %ext, <2 x i64> addrspace(3)* %out
272*9880d681SAndroid Build Coastguard Worker  ret void
273*9880d681SAndroid Build Coastguard Worker}
274*9880d681SAndroid Build Coastguard Worker
275*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_zextload_v3i1_to_v3i64:
276*9880d681SAndroid Build Coastguard Workerdefine void @local_zextload_v3i1_to_v3i64(<3 x i64> addrspace(3)* %out, <3 x i1> addrspace(3)* %in) #0 {
277*9880d681SAndroid Build Coastguard Worker  %load = load <3 x i1>, <3 x i1> addrspace(3)* %in
278*9880d681SAndroid Build Coastguard Worker  %ext = zext <3 x i1> %load to <3 x i64>
279*9880d681SAndroid Build Coastguard Worker  store <3 x i64> %ext, <3 x i64> addrspace(3)* %out
280*9880d681SAndroid Build Coastguard Worker  ret void
281*9880d681SAndroid Build Coastguard Worker}
282*9880d681SAndroid Build Coastguard Worker
283*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_sextload_v3i1_to_v3i64:
284*9880d681SAndroid Build Coastguard Workerdefine void @local_sextload_v3i1_to_v3i64(<3 x i64> addrspace(3)* %out, <3 x i1> addrspace(3)* %in) #0 {
285*9880d681SAndroid Build Coastguard Worker  %load = load <3 x i1>, <3 x i1> addrspace(3)* %in
286*9880d681SAndroid Build Coastguard Worker  %ext = sext <3 x i1> %load to <3 x i64>
287*9880d681SAndroid Build Coastguard Worker  store <3 x i64> %ext, <3 x i64> addrspace(3)* %out
288*9880d681SAndroid Build Coastguard Worker  ret void
289*9880d681SAndroid Build Coastguard Worker}
290*9880d681SAndroid Build Coastguard Worker
291*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_zextload_v4i1_to_v4i64:
292*9880d681SAndroid Build Coastguard Workerdefine void @local_zextload_v4i1_to_v4i64(<4 x i64> addrspace(3)* %out, <4 x i1> addrspace(3)* %in) #0 {
293*9880d681SAndroid Build Coastguard Worker  %load = load <4 x i1>, <4 x i1> addrspace(3)* %in
294*9880d681SAndroid Build Coastguard Worker  %ext = zext <4 x i1> %load to <4 x i64>
295*9880d681SAndroid Build Coastguard Worker  store <4 x i64> %ext, <4 x i64> addrspace(3)* %out
296*9880d681SAndroid Build Coastguard Worker  ret void
297*9880d681SAndroid Build Coastguard Worker}
298*9880d681SAndroid Build Coastguard Worker
299*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_sextload_v4i1_to_v4i64:
300*9880d681SAndroid Build Coastguard Workerdefine void @local_sextload_v4i1_to_v4i64(<4 x i64> addrspace(3)* %out, <4 x i1> addrspace(3)* %in) #0 {
301*9880d681SAndroid Build Coastguard Worker  %load = load <4 x i1>, <4 x i1> addrspace(3)* %in
302*9880d681SAndroid Build Coastguard Worker  %ext = sext <4 x i1> %load to <4 x i64>
303*9880d681SAndroid Build Coastguard Worker  store <4 x i64> %ext, <4 x i64> addrspace(3)* %out
304*9880d681SAndroid Build Coastguard Worker  ret void
305*9880d681SAndroid Build Coastguard Worker}
306*9880d681SAndroid Build Coastguard Worker
307*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_zextload_v8i1_to_v8i64:
308*9880d681SAndroid Build Coastguard Workerdefine void @local_zextload_v8i1_to_v8i64(<8 x i64> addrspace(3)* %out, <8 x i1> addrspace(3)* %in) #0 {
309*9880d681SAndroid Build Coastguard Worker  %load = load <8 x i1>, <8 x i1> addrspace(3)* %in
310*9880d681SAndroid Build Coastguard Worker  %ext = zext <8 x i1> %load to <8 x i64>
311*9880d681SAndroid Build Coastguard Worker  store <8 x i64> %ext, <8 x i64> addrspace(3)* %out
312*9880d681SAndroid Build Coastguard Worker  ret void
313*9880d681SAndroid Build Coastguard Worker}
314*9880d681SAndroid Build Coastguard Worker
315*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_sextload_v8i1_to_v8i64:
316*9880d681SAndroid Build Coastguard Workerdefine void @local_sextload_v8i1_to_v8i64(<8 x i64> addrspace(3)* %out, <8 x i1> addrspace(3)* %in) #0 {
317*9880d681SAndroid Build Coastguard Worker  %load = load <8 x i1>, <8 x i1> addrspace(3)* %in
318*9880d681SAndroid Build Coastguard Worker  %ext = sext <8 x i1> %load to <8 x i64>
319*9880d681SAndroid Build Coastguard Worker  store <8 x i64> %ext, <8 x i64> addrspace(3)* %out
320*9880d681SAndroid Build Coastguard Worker  ret void
321*9880d681SAndroid Build Coastguard Worker}
322*9880d681SAndroid Build Coastguard Worker
323*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_zextload_v16i1_to_v16i64:
324*9880d681SAndroid Build Coastguard Workerdefine void @local_zextload_v16i1_to_v16i64(<16 x i64> addrspace(3)* %out, <16 x i1> addrspace(3)* %in) #0 {
325*9880d681SAndroid Build Coastguard Worker  %load = load <16 x i1>, <16 x i1> addrspace(3)* %in
326*9880d681SAndroid Build Coastguard Worker  %ext = zext <16 x i1> %load to <16 x i64>
327*9880d681SAndroid Build Coastguard Worker  store <16 x i64> %ext, <16 x i64> addrspace(3)* %out
328*9880d681SAndroid Build Coastguard Worker  ret void
329*9880d681SAndroid Build Coastguard Worker}
330*9880d681SAndroid Build Coastguard Worker
331*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_sextload_v16i1_to_v16i64:
332*9880d681SAndroid Build Coastguard Workerdefine void @local_sextload_v16i1_to_v16i64(<16 x i64> addrspace(3)* %out, <16 x i1> addrspace(3)* %in) #0 {
333*9880d681SAndroid Build Coastguard Worker  %load = load <16 x i1>, <16 x i1> addrspace(3)* %in
334*9880d681SAndroid Build Coastguard Worker  %ext = sext <16 x i1> %load to <16 x i64>
335*9880d681SAndroid Build Coastguard Worker  store <16 x i64> %ext, <16 x i64> addrspace(3)* %out
336*9880d681SAndroid Build Coastguard Worker  ret void
337*9880d681SAndroid Build Coastguard Worker}
338*9880d681SAndroid Build Coastguard Worker
339*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_zextload_v32i1_to_v32i64:
340*9880d681SAndroid Build Coastguard Workerdefine void @local_zextload_v32i1_to_v32i64(<32 x i64> addrspace(3)* %out, <32 x i1> addrspace(3)* %in) #0 {
341*9880d681SAndroid Build Coastguard Worker  %load = load <32 x i1>, <32 x i1> addrspace(3)* %in
342*9880d681SAndroid Build Coastguard Worker  %ext = zext <32 x i1> %load to <32 x i64>
343*9880d681SAndroid Build Coastguard Worker  store <32 x i64> %ext, <32 x i64> addrspace(3)* %out
344*9880d681SAndroid Build Coastguard Worker  ret void
345*9880d681SAndroid Build Coastguard Worker}
346*9880d681SAndroid Build Coastguard Worker
347*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_sextload_v32i1_to_v32i64:
348*9880d681SAndroid Build Coastguard Workerdefine void @local_sextload_v32i1_to_v32i64(<32 x i64> addrspace(3)* %out, <32 x i1> addrspace(3)* %in) #0 {
349*9880d681SAndroid Build Coastguard Worker  %load = load <32 x i1>, <32 x i1> addrspace(3)* %in
350*9880d681SAndroid Build Coastguard Worker  %ext = sext <32 x i1> %load to <32 x i64>
351*9880d681SAndroid Build Coastguard Worker  store <32 x i64> %ext, <32 x i64> addrspace(3)* %out
352*9880d681SAndroid Build Coastguard Worker  ret void
353*9880d681SAndroid Build Coastguard Worker}
354*9880d681SAndroid Build Coastguard Worker
355*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_zextload_v64i1_to_v64i64:
356*9880d681SAndroid Build Coastguard Workerdefine void @local_zextload_v64i1_to_v64i64(<64 x i64> addrspace(3)* %out, <64 x i1> addrspace(3)* %in) #0 {
357*9880d681SAndroid Build Coastguard Worker  %load = load <64 x i1>, <64 x i1> addrspace(3)* %in
358*9880d681SAndroid Build Coastguard Worker  %ext = zext <64 x i1> %load to <64 x i64>
359*9880d681SAndroid Build Coastguard Worker  store <64 x i64> %ext, <64 x i64> addrspace(3)* %out
360*9880d681SAndroid Build Coastguard Worker  ret void
361*9880d681SAndroid Build Coastguard Worker}
362*9880d681SAndroid Build Coastguard Worker
363*9880d681SAndroid Build Coastguard Worker; FUNC-LABEL: {{^}}local_sextload_v64i1_to_v64i64:
364*9880d681SAndroid Build Coastguard Workerdefine void @local_sextload_v64i1_to_v64i64(<64 x i64> addrspace(3)* %out, <64 x i1> addrspace(3)* %in) #0 {
365*9880d681SAndroid Build Coastguard Worker  %load = load <64 x i1>, <64 x i1> addrspace(3)* %in
366*9880d681SAndroid Build Coastguard Worker  %ext = sext <64 x i1> %load to <64 x i64>
367*9880d681SAndroid Build Coastguard Worker  store <64 x i64> %ext, <64 x i64> addrspace(3)* %out
368*9880d681SAndroid Build Coastguard Worker  ret void
369*9880d681SAndroid Build Coastguard Worker}
370*9880d681SAndroid Build Coastguard Worker
371*9880d681SAndroid Build Coastguard Workerattributes #0 = { nounwind }
372