[AMDGPU] Add True16 register classes.
[llvm-project.git] / llvm / test / CodeGen / AMDGPU / llvm.amdgcn.raw.ptr.buffer.load.ll
blob6a04a0cfed3551d908c213da722990dee3f424fb
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ;RUN: llc < %s -march=amdgcn -mcpu=verde -verify-machineinstrs | FileCheck %s --check-prefixes=PREGFX10
3 ;RUN: llc < %s -march=amdgcn -mcpu=tonga -verify-machineinstrs | FileCheck %s --check-prefixes=PREGFX10
4 ;RUN: llc < %s -march=amdgcn -mcpu=gfx1010 -verify-machineinstrs | FileCheck %s --check-prefixes=GFX10
5 ;RUN: llc < %s -march=amdgcn -mcpu=gfx1100 -amdgpu-enable-delay-alu=0 -verify-machineinstrs | FileCheck %s --check-prefixes=GFX11
7 define amdgpu_ps {<4 x float>, <4 x float>, <4 x float>} @buffer_load(ptr addrspace(8) inreg) {
8 ; PREGFX10-LABEL: buffer_load:
9 ; PREGFX10:       ; %bb.0: ; %main_body
10 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[0:3], off, s[0:3], 0
11 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[4:7], off, s[0:3], 0 glc
12 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[8:11], off, s[0:3], 0 slc
13 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
14 ; PREGFX10-NEXT:    ; return to shader part epilog
16 ; GFX10-LABEL: buffer_load:
17 ; GFX10:       ; %bb.0: ; %main_body
18 ; GFX10-NEXT:    s_clause 0x2
19 ; GFX10-NEXT:    buffer_load_dwordx4 v[0:3], off, s[0:3], 0
20 ; GFX10-NEXT:    buffer_load_dwordx4 v[4:7], off, s[0:3], 0 glc
21 ; GFX10-NEXT:    buffer_load_dwordx4 v[8:11], off, s[0:3], 0 slc
22 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
23 ; GFX10-NEXT:    ; return to shader part epilog
25 ; GFX11-LABEL: buffer_load:
26 ; GFX11:       ; %bb.0: ; %main_body
27 ; GFX11-NEXT:    s_clause 0x2
28 ; GFX11-NEXT:    buffer_load_b128 v[0:3], off, s[0:3], 0
29 ; GFX11-NEXT:    buffer_load_b128 v[4:7], off, s[0:3], 0 glc
30 ; GFX11-NEXT:    buffer_load_b128 v[8:11], off, s[0:3], 0 slc
31 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
32 ; GFX11-NEXT:    ; return to shader part epilog
33 main_body:
34   %data = call <4 x float> @llvm.amdgcn.raw.ptr.buffer.load.v4f32(ptr addrspace(8) %0, i32 0, i32 0, i32 0)
35   %data_glc = call <4 x float> @llvm.amdgcn.raw.ptr.buffer.load.v4f32(ptr addrspace(8) %0, i32 0, i32 0, i32 1)
36   %data_slc = call <4 x float> @llvm.amdgcn.raw.ptr.buffer.load.v4f32(ptr addrspace(8) %0, i32 0, i32 0, i32 2)
37   %r0 = insertvalue {<4 x float>, <4 x float>, <4 x float>} undef, <4 x float> %data, 0
38   %r1 = insertvalue {<4 x float>, <4 x float>, <4 x float>} %r0, <4 x float> %data_glc, 1
39   %r2 = insertvalue {<4 x float>, <4 x float>, <4 x float>} %r1, <4 x float> %data_slc, 2
40   ret {<4 x float>, <4 x float>, <4 x float>} %r2
43 define amdgpu_ps {<4 x float>, <4 x float>, <4 x float>} @buffer_load_dlc(ptr addrspace(8) inreg) {
44 ; PREGFX10-LABEL: buffer_load_dlc:
45 ; PREGFX10:       ; %bb.0: ; %main_body
46 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[0:3], off, s[0:3], 0
47 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[4:7], off, s[0:3], 0 glc
48 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[8:11], off, s[0:3], 0 slc
49 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
50 ; PREGFX10-NEXT:    ; return to shader part epilog
52 ; GFX10-LABEL: buffer_load_dlc:
53 ; GFX10:       ; %bb.0: ; %main_body
54 ; GFX10-NEXT:    s_clause 0x2
55 ; GFX10-NEXT:    buffer_load_dwordx4 v[0:3], off, s[0:3], 0 dlc
56 ; GFX10-NEXT:    buffer_load_dwordx4 v[4:7], off, s[0:3], 0 glc dlc
57 ; GFX10-NEXT:    buffer_load_dwordx4 v[8:11], off, s[0:3], 0 slc dlc
58 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
59 ; GFX10-NEXT:    ; return to shader part epilog
61 ; GFX11-LABEL: buffer_load_dlc:
62 ; GFX11:       ; %bb.0: ; %main_body
63 ; GFX11-NEXT:    s_clause 0x2
64 ; GFX11-NEXT:    buffer_load_b128 v[0:3], off, s[0:3], 0 dlc
65 ; GFX11-NEXT:    buffer_load_b128 v[4:7], off, s[0:3], 0 glc dlc
66 ; GFX11-NEXT:    buffer_load_b128 v[8:11], off, s[0:3], 0 slc dlc
67 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
68 ; GFX11-NEXT:    ; return to shader part epilog
69 main_body:
70   %data = call <4 x float> @llvm.amdgcn.raw.ptr.buffer.load.v4f32(ptr addrspace(8) %0, i32 0, i32 0, i32 4)
71   %data_glc = call <4 x float> @llvm.amdgcn.raw.ptr.buffer.load.v4f32(ptr addrspace(8) %0, i32 0, i32 0, i32 5)
72   %data_slc = call <4 x float> @llvm.amdgcn.raw.ptr.buffer.load.v4f32(ptr addrspace(8) %0, i32 0, i32 0, i32 6)
73   %r0 = insertvalue {<4 x float>, <4 x float>, <4 x float>} undef, <4 x float> %data, 0
74   %r1 = insertvalue {<4 x float>, <4 x float>, <4 x float>} %r0, <4 x float> %data_glc, 1
75   %r2 = insertvalue {<4 x float>, <4 x float>, <4 x float>} %r1, <4 x float> %data_slc, 2
76   ret {<4 x float>, <4 x float>, <4 x float>} %r2
79 define amdgpu_ps <4 x float> @buffer_load_immoffs(ptr addrspace(8) inreg) {
80 ; PREGFX10-LABEL: buffer_load_immoffs:
81 ; PREGFX10:       ; %bb.0: ; %main_body
82 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[0:3], off, s[0:3], 0 offset:40
83 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
84 ; PREGFX10-NEXT:    ; return to shader part epilog
86 ; GFX10-LABEL: buffer_load_immoffs:
87 ; GFX10:       ; %bb.0: ; %main_body
88 ; GFX10-NEXT:    buffer_load_dwordx4 v[0:3], off, s[0:3], 0 offset:40
89 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
90 ; GFX10-NEXT:    ; return to shader part epilog
92 ; GFX11-LABEL: buffer_load_immoffs:
93 ; GFX11:       ; %bb.0: ; %main_body
94 ; GFX11-NEXT:    buffer_load_b128 v[0:3], off, s[0:3], 0 offset:40
95 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
96 ; GFX11-NEXT:    ; return to shader part epilog
97 main_body:
98   %data = call <4 x float> @llvm.amdgcn.raw.ptr.buffer.load.v4f32(ptr addrspace(8) %0, i32 40, i32 0, i32 0)
99   ret <4 x float> %data
102 define amdgpu_ps <4 x float> @buffer_load_immoffs_large(ptr addrspace(8) inreg) {
103 ; PREGFX10-LABEL: buffer_load_immoffs_large:
104 ; PREGFX10:       ; %bb.0: ; %main_body
105 ; PREGFX10-NEXT:    s_movk_i32 s4, 0x1ffc
106 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[0:3], off, s[0:3], s4 offset:4
107 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
108 ; PREGFX10-NEXT:    ; return to shader part epilog
110 ; GFX10-LABEL: buffer_load_immoffs_large:
111 ; GFX10:       ; %bb.0: ; %main_body
112 ; GFX10-NEXT:    s_movk_i32 s4, 0x1ffc
113 ; GFX10-NEXT:    buffer_load_dwordx4 v[0:3], off, s[0:3], s4 offset:4
114 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
115 ; GFX10-NEXT:    ; return to shader part epilog
117 ; GFX11-LABEL: buffer_load_immoffs_large:
118 ; GFX11:       ; %bb.0: ; %main_body
119 ; GFX11-NEXT:    s_movk_i32 s4, 0x1ffc
120 ; GFX11-NEXT:    buffer_load_b128 v[0:3], off, s[0:3], s4 offset:4
121 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
122 ; GFX11-NEXT:    ; return to shader part epilog
123 main_body:
124   %data = call <4 x float> @llvm.amdgcn.raw.ptr.buffer.load.v4f32(ptr addrspace(8) %0, i32 4, i32 8188, i32 0)
125   ret <4 x float> %data
128 define amdgpu_ps <4 x float> @buffer_load_ofs(ptr addrspace(8) inreg, i32) {
129 ; PREGFX10-LABEL: buffer_load_ofs:
130 ; PREGFX10:       ; %bb.0: ; %main_body
131 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[0:3], v0, s[0:3], 0 offen
132 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
133 ; PREGFX10-NEXT:    ; return to shader part epilog
135 ; GFX10-LABEL: buffer_load_ofs:
136 ; GFX10:       ; %bb.0: ; %main_body
137 ; GFX10-NEXT:    buffer_load_dwordx4 v[0:3], v0, s[0:3], 0 offen
138 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
139 ; GFX10-NEXT:    ; return to shader part epilog
141 ; GFX11-LABEL: buffer_load_ofs:
142 ; GFX11:       ; %bb.0: ; %main_body
143 ; GFX11-NEXT:    buffer_load_b128 v[0:3], v0, s[0:3], 0 offen
144 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
145 ; GFX11-NEXT:    ; return to shader part epilog
146 main_body:
147   %data = call <4 x float> @llvm.amdgcn.raw.ptr.buffer.load.v4f32(ptr addrspace(8) %0, i32 %1, i32 0, i32 0)
148   ret <4 x float> %data
151 define amdgpu_ps <4 x float> @buffer_load_ofs_imm(ptr addrspace(8) inreg, i32) {
152 ; PREGFX10-LABEL: buffer_load_ofs_imm:
153 ; PREGFX10:       ; %bb.0: ; %main_body
154 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[0:3], v0, s[0:3], 0 offen offset:60
155 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
156 ; PREGFX10-NEXT:    ; return to shader part epilog
158 ; GFX10-LABEL: buffer_load_ofs_imm:
159 ; GFX10:       ; %bb.0: ; %main_body
160 ; GFX10-NEXT:    buffer_load_dwordx4 v[0:3], v0, s[0:3], 0 offen offset:60
161 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
162 ; GFX10-NEXT:    ; return to shader part epilog
164 ; GFX11-LABEL: buffer_load_ofs_imm:
165 ; GFX11:       ; %bb.0: ; %main_body
166 ; GFX11-NEXT:    buffer_load_b128 v[0:3], v0, s[0:3], 0 offen offset:60
167 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
168 ; GFX11-NEXT:    ; return to shader part epilog
169 main_body:
170   %ofs = add i32 %1, 60
171   %data = call <4 x float> @llvm.amdgcn.raw.ptr.buffer.load.v4f32(ptr addrspace(8) %0, i32 %ofs, i32 0, i32 0)
172   ret <4 x float> %data
175 define amdgpu_ps <4 x float> @buffer_load_voffset_large_12bit(ptr addrspace(8) inreg) {
176 ; PREGFX10-LABEL: buffer_load_voffset_large_12bit:
177 ; PREGFX10:       ; %bb.0: ; %main_body
178 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[0:3], off, s[0:3], 0 offset:4092
179 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
180 ; PREGFX10-NEXT:    ; return to shader part epilog
182 ; GFX10-LABEL: buffer_load_voffset_large_12bit:
183 ; GFX10:       ; %bb.0: ; %main_body
184 ; GFX10-NEXT:    buffer_load_dwordx4 v[0:3], off, s[0:3], 0 offset:4092
185 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
186 ; GFX10-NEXT:    ; return to shader part epilog
188 ; GFX11-LABEL: buffer_load_voffset_large_12bit:
189 ; GFX11:       ; %bb.0: ; %main_body
190 ; GFX11-NEXT:    buffer_load_b128 v[0:3], off, s[0:3], 0 offset:4092
191 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
192 ; GFX11-NEXT:    ; return to shader part epilog
193 main_body:
194   %data = call <4 x float> @llvm.amdgcn.raw.ptr.buffer.load.v4f32(ptr addrspace(8) %0, i32 4092, i32 0, i32 0)
195   ret <4 x float> %data
198 define amdgpu_ps <4 x float> @buffer_load_voffset_large_13bit(ptr addrspace(8) inreg) {
199 ; PREGFX10-LABEL: buffer_load_voffset_large_13bit:
200 ; PREGFX10:       ; %bb.0: ; %main_body
201 ; PREGFX10-NEXT:    v_mov_b32_e32 v0, 0x1000
202 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[0:3], v0, s[0:3], 0 offen offset:4092
203 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
204 ; PREGFX10-NEXT:    ; return to shader part epilog
206 ; GFX10-LABEL: buffer_load_voffset_large_13bit:
207 ; GFX10:       ; %bb.0: ; %main_body
208 ; GFX10-NEXT:    v_mov_b32_e32 v0, 0x1000
209 ; GFX10-NEXT:    buffer_load_dwordx4 v[0:3], v0, s[0:3], 0 offen offset:4092
210 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
211 ; GFX10-NEXT:    ; return to shader part epilog
213 ; GFX11-LABEL: buffer_load_voffset_large_13bit:
214 ; GFX11:       ; %bb.0: ; %main_body
215 ; GFX11-NEXT:    v_mov_b32_e32 v0, 0x1000
216 ; GFX11-NEXT:    buffer_load_b128 v[0:3], v0, s[0:3], 0 offen offset:4092
217 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
218 ; GFX11-NEXT:    ; return to shader part epilog
219 main_body:
220   %data = call <4 x float> @llvm.amdgcn.raw.ptr.buffer.load.v4f32(ptr addrspace(8) %0, i32 8188, i32 0, i32 0)
221   ret <4 x float> %data
224 define amdgpu_ps <4 x float> @buffer_load_voffset_large_16bit(ptr addrspace(8) inreg) {
225 ; PREGFX10-LABEL: buffer_load_voffset_large_16bit:
226 ; PREGFX10:       ; %bb.0: ; %main_body
227 ; PREGFX10-NEXT:    v_mov_b32_e32 v0, 0xf000
228 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[0:3], v0, s[0:3], 0 offen offset:4092
229 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
230 ; PREGFX10-NEXT:    ; return to shader part epilog
232 ; GFX10-LABEL: buffer_load_voffset_large_16bit:
233 ; GFX10:       ; %bb.0: ; %main_body
234 ; GFX10-NEXT:    v_mov_b32_e32 v0, 0xf000
235 ; GFX10-NEXT:    buffer_load_dwordx4 v[0:3], v0, s[0:3], 0 offen offset:4092
236 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
237 ; GFX10-NEXT:    ; return to shader part epilog
239 ; GFX11-LABEL: buffer_load_voffset_large_16bit:
240 ; GFX11:       ; %bb.0: ; %main_body
241 ; GFX11-NEXT:    v_mov_b32_e32 v0, 0xf000
242 ; GFX11-NEXT:    buffer_load_b128 v[0:3], v0, s[0:3], 0 offen offset:4092
243 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
244 ; GFX11-NEXT:    ; return to shader part epilog
245 main_body:
246   %data = call <4 x float> @llvm.amdgcn.raw.ptr.buffer.load.v4f32(ptr addrspace(8) %0, i32 65532, i32 0, i32 0)
247   ret <4 x float> %data
250 define amdgpu_ps <4 x float> @buffer_load_voffset_large_23bit(ptr addrspace(8) inreg) {
251 ; PREGFX10-LABEL: buffer_load_voffset_large_23bit:
252 ; PREGFX10:       ; %bb.0: ; %main_body
253 ; PREGFX10-NEXT:    v_mov_b32_e32 v0, 0x7ff000
254 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[0:3], v0, s[0:3], 0 offen offset:4092
255 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
256 ; PREGFX10-NEXT:    ; return to shader part epilog
258 ; GFX10-LABEL: buffer_load_voffset_large_23bit:
259 ; GFX10:       ; %bb.0: ; %main_body
260 ; GFX10-NEXT:    v_mov_b32_e32 v0, 0x7ff000
261 ; GFX10-NEXT:    buffer_load_dwordx4 v[0:3], v0, s[0:3], 0 offen offset:4092
262 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
263 ; GFX10-NEXT:    ; return to shader part epilog
265 ; GFX11-LABEL: buffer_load_voffset_large_23bit:
266 ; GFX11:       ; %bb.0: ; %main_body
267 ; GFX11-NEXT:    v_mov_b32_e32 v0, 0x7ff000
268 ; GFX11-NEXT:    buffer_load_b128 v[0:3], v0, s[0:3], 0 offen offset:4092
269 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
270 ; GFX11-NEXT:    ; return to shader part epilog
271 main_body:
272   %data = call <4 x float> @llvm.amdgcn.raw.ptr.buffer.load.v4f32(ptr addrspace(8) %0, i32 8388604, i32 0, i32 0)
273   ret <4 x float> %data
276 define amdgpu_ps <4 x float> @buffer_load_voffset_large_24bit(ptr addrspace(8) inreg) {
277 ; PREGFX10-LABEL: buffer_load_voffset_large_24bit:
278 ; PREGFX10:       ; %bb.0: ; %main_body
279 ; PREGFX10-NEXT:    v_mov_b32_e32 v0, 0xfff000
280 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[0:3], v0, s[0:3], 0 offen offset:4092
281 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
282 ; PREGFX10-NEXT:    ; return to shader part epilog
284 ; GFX10-LABEL: buffer_load_voffset_large_24bit:
285 ; GFX10:       ; %bb.0: ; %main_body
286 ; GFX10-NEXT:    v_mov_b32_e32 v0, 0xfff000
287 ; GFX10-NEXT:    buffer_load_dwordx4 v[0:3], v0, s[0:3], 0 offen offset:4092
288 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
289 ; GFX10-NEXT:    ; return to shader part epilog
291 ; GFX11-LABEL: buffer_load_voffset_large_24bit:
292 ; GFX11:       ; %bb.0: ; %main_body
293 ; GFX11-NEXT:    v_mov_b32_e32 v0, 0xfff000
294 ; GFX11-NEXT:    buffer_load_b128 v[0:3], v0, s[0:3], 0 offen offset:4092
295 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
296 ; GFX11-NEXT:    ; return to shader part epilog
297 main_body:
298   %data = call <4 x float> @llvm.amdgcn.raw.ptr.buffer.load.v4f32(ptr addrspace(8) %0, i32 16777212, i32 0, i32 0)
299   ret <4 x float> %data
303 define amdgpu_ps float @buffer_load_x1(ptr addrspace(8) inreg %rsrc, i32 %ofs) {
304 ; PREGFX10-LABEL: buffer_load_x1:
305 ; PREGFX10:       ; %bb.0: ; %main_body
306 ; PREGFX10-NEXT:    buffer_load_dword v0, v0, s[0:3], 0 offen
307 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
308 ; PREGFX10-NEXT:    ; return to shader part epilog
310 ; GFX10-LABEL: buffer_load_x1:
311 ; GFX10:       ; %bb.0: ; %main_body
312 ; GFX10-NEXT:    buffer_load_dword v0, v0, s[0:3], 0 offen
313 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
314 ; GFX10-NEXT:    ; return to shader part epilog
316 ; GFX11-LABEL: buffer_load_x1:
317 ; GFX11:       ; %bb.0: ; %main_body
318 ; GFX11-NEXT:    buffer_load_b32 v0, v0, s[0:3], 0 offen
319 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
320 ; GFX11-NEXT:    ; return to shader part epilog
321 main_body:
322   %data = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 %ofs, i32 0, i32 0)
323   ret float %data
326 define amdgpu_ps <2 x float> @buffer_load_x2(ptr addrspace(8) inreg %rsrc, i32 %ofs) {
327 ; PREGFX10-LABEL: buffer_load_x2:
328 ; PREGFX10:       ; %bb.0: ; %main_body
329 ; PREGFX10-NEXT:    buffer_load_dwordx2 v[0:1], v0, s[0:3], 0 offen
330 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
331 ; PREGFX10-NEXT:    ; return to shader part epilog
333 ; GFX10-LABEL: buffer_load_x2:
334 ; GFX10:       ; %bb.0: ; %main_body
335 ; GFX10-NEXT:    buffer_load_dwordx2 v[0:1], v0, s[0:3], 0 offen
336 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
337 ; GFX10-NEXT:    ; return to shader part epilog
339 ; GFX11-LABEL: buffer_load_x2:
340 ; GFX11:       ; %bb.0: ; %main_body
341 ; GFX11-NEXT:    buffer_load_b64 v[0:1], v0, s[0:3], 0 offen
342 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
343 ; GFX11-NEXT:    ; return to shader part epilog
344 main_body:
345   %data = call <2 x float> @llvm.amdgcn.raw.ptr.buffer.load.v2f32(ptr addrspace(8) %rsrc, i32 %ofs, i32 0, i32 0)
346   ret <2 x float> %data
349 define amdgpu_ps <4 x float> @buffer_load_negative_offset(ptr addrspace(8) inreg, i32 %ofs) {
350 ; GFX10-LABEL: buffer_load_negative_offset:
351 ; GFX10:       ; %bb.0: ; %main_body
352 ; GFX10-NEXT:    v_add_nc_u32_e32 v0, -16, v0
353 ; GFX10-NEXT:    buffer_load_dwordx4 v[0:3], v0, s[0:3], 0 offen
354 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
355 ; GFX10-NEXT:    ; return to shader part epilog
357 ; GFX11-LABEL: buffer_load_negative_offset:
358 ; GFX11:       ; %bb.0: ; %main_body
359 ; GFX11-NEXT:    v_add_nc_u32_e32 v0, -16, v0
360 ; GFX11-NEXT:    buffer_load_b128 v[0:3], v0, s[0:3], 0 offen
361 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
362 ; GFX11-NEXT:    ; return to shader part epilog
363 main_body:
364   %ofs.1 = add i32 %ofs, -16
365   %data = call <4 x float> @llvm.amdgcn.raw.ptr.buffer.load.v4f32(ptr addrspace(8) %0, i32 %ofs.1, i32 0, i32 0)
366   ret <4 x float> %data
369 define amdgpu_ps float @buffer_load_mmo(ptr addrspace(8) inreg %rsrc, ptr addrspace(3) %lds) {
370 ; GFX10-LABEL: buffer_load_mmo:
371 ; GFX10:       ; %bb.0: ; %entry
372 ; GFX10-NEXT:    buffer_load_dword v1, off, s[0:3], 0
373 ; GFX10-NEXT:    v_mov_b32_e32 v2, 0
374 ; GFX10-NEXT:    ds_write2_b32 v0, v2, v2 offset1:4
375 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
376 ; GFX10-NEXT:    v_mov_b32_e32 v0, v1
377 ; GFX10-NEXT:    s_waitcnt lgkmcnt(0)
378 ; GFX10-NEXT:    ; return to shader part epilog
380 ; GFX11-LABEL: buffer_load_mmo:
381 ; GFX11:       ; %bb.0: ; %entry
382 ; GFX11-NEXT:    buffer_load_b32 v1, off, s[0:3], 0
383 ; GFX11-NEXT:    v_mov_b32_e32 v2, 0
384 ; GFX11-NEXT:    ds_store_2addr_b32 v0, v2, v2 offset1:4
385 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
386 ; GFX11-NEXT:    v_mov_b32_e32 v0, v1
387 ; GFX11-NEXT:    s_waitcnt lgkmcnt(0)
388 ; GFX11-NEXT:    ; return to shader part epilog
389 entry:
390   store float 0.0, ptr addrspace(3) %lds
391   %val = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 0, i32 0, i32 0)
392   %tmp2 = getelementptr float, ptr addrspace(3) %lds, i32 4
393   store float 0.0, ptr addrspace(3) %tmp2
394   ret float %val
397 define amdgpu_ps void @buffer_load_x1_offen_merged_and(ptr addrspace(8) inreg %rsrc, i32 %a) {
398 ; PREGFX10-LABEL: buffer_load_x1_offen_merged_and:
399 ; PREGFX10:       ; %bb.0: ; %main_body
400 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[1:4], v0, s[0:3], 0 offen offset:4
401 ; PREGFX10-NEXT:    buffer_load_dwordx2 v[5:6], v0, s[0:3], 0 offen offset:28
402 ; PREGFX10-NEXT:    s_waitcnt vmcnt(1)
403 ; PREGFX10-NEXT:    exp mrt0 v1, v2, v3, v4 done vm
404 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
405 ; PREGFX10-NEXT:    exp mrt0 v5, v6, v0, v0 done vm
406 ; PREGFX10-NEXT:    s_endpgm
408 ; GFX10-LABEL: buffer_load_x1_offen_merged_and:
409 ; GFX10:       ; %bb.0: ; %main_body
410 ; GFX10-NEXT:    s_clause 0x1
411 ; GFX10-NEXT:    buffer_load_dwordx4 v[1:4], v0, s[0:3], 0 offen offset:4
412 ; GFX10-NEXT:    buffer_load_dwordx2 v[5:6], v0, s[0:3], 0 offen offset:28
413 ; GFX10-NEXT:    s_waitcnt vmcnt(1)
414 ; GFX10-NEXT:    exp mrt0 v1, v2, v3, v4 done vm
415 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
416 ; GFX10-NEXT:    exp mrt0 v5, v6, v0, v0 done vm
417 ; GFX10-NEXT:    s_endpgm
419 ; GFX11-LABEL: buffer_load_x1_offen_merged_and:
420 ; GFX11:       ; %bb.0: ; %main_body
421 ; GFX11-NEXT:    s_clause 0x1
422 ; GFX11-NEXT:    buffer_load_b128 v[1:4], v0, s[0:3], 0 offen offset:4
423 ; GFX11-NEXT:    buffer_load_b64 v[5:6], v0, s[0:3], 0 offen offset:28
424 ; GFX11-NEXT:    s_waitcnt vmcnt(1)
425 ; GFX11-NEXT:    exp mrt0 v1, v2, v3, v4 done
426 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
427 ; GFX11-NEXT:    exp mrt0 v5, v6, v0, v0 done
428 ; GFX11-NEXT:    s_endpgm
429 main_body:
430   %a1 = add i32 %a, 4
431   %a2 = add i32 %a, 8
432   %a3 = add i32 %a, 12
433   %a4 = add i32 %a, 16
434   %a5 = add i32 %a, 28
435   %a6 = add i32 %a, 32
436   %r1 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 %a1, i32 0, i32 0)
437   %r2 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 %a2, i32 0, i32 0)
438   %r3 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 %a3, i32 0, i32 0)
439   %r4 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 %a4, i32 0, i32 0)
440   %r5 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 %a5, i32 0, i32 0)
441   %r6 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 %a6, i32 0, i32 0)
442   call void @llvm.amdgcn.exp.f32(i32 0, i32 15, float %r1, float %r2, float %r3, float %r4, i1 true, i1 true)
443   call void @llvm.amdgcn.exp.f32(i32 0, i32 15, float %r5, float %r6, float undef, float undef, i1 true, i1 true)
444   ret void
447 define amdgpu_ps void @buffer_load_x1_offen_merged_or(ptr addrspace(8) inreg %rsrc, i32 %inp) {
448 ; PREGFX10-LABEL: buffer_load_x1_offen_merged_or:
449 ; PREGFX10:       ; %bb.0: ; %main_body
450 ; PREGFX10-NEXT:    v_lshlrev_b32_e32 v4, 6, v0
451 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[0:3], v4, s[0:3], 0 offen offset:4
452 ; PREGFX10-NEXT:    buffer_load_dwordx2 v[4:5], v4, s[0:3], 0 offen offset:28
453 ; PREGFX10-NEXT:    s_waitcnt vmcnt(1)
454 ; PREGFX10-NEXT:    exp mrt0 v0, v1, v2, v3 done vm
455 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
456 ; PREGFX10-NEXT:    exp mrt0 v4, v5, v0, v0 done vm
457 ; PREGFX10-NEXT:    s_endpgm
459 ; GFX10-LABEL: buffer_load_x1_offen_merged_or:
460 ; GFX10:       ; %bb.0: ; %main_body
461 ; GFX10-NEXT:    v_lshlrev_b32_e32 v6, 6, v0
462 ; GFX10-NEXT:    s_clause 0x1
463 ; GFX10-NEXT:    buffer_load_dwordx4 v[0:3], v6, s[0:3], 0 offen offset:4
464 ; GFX10-NEXT:    buffer_load_dwordx2 v[4:5], v6, s[0:3], 0 offen offset:28
465 ; GFX10-NEXT:    s_waitcnt vmcnt(1)
466 ; GFX10-NEXT:    exp mrt0 v0, v1, v2, v3 done vm
467 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
468 ; GFX10-NEXT:    exp mrt0 v4, v5, v0, v0 done vm
469 ; GFX10-NEXT:    s_endpgm
471 ; GFX11-LABEL: buffer_load_x1_offen_merged_or:
472 ; GFX11:       ; %bb.0: ; %main_body
473 ; GFX11-NEXT:    v_lshlrev_b32_e32 v4, 6, v0
474 ; GFX11-NEXT:    s_clause 0x1
475 ; GFX11-NEXT:    buffer_load_b128 v[0:3], v4, s[0:3], 0 offen offset:4
476 ; GFX11-NEXT:    buffer_load_b64 v[4:5], v4, s[0:3], 0 offen offset:28
477 ; GFX11-NEXT:    s_waitcnt vmcnt(1)
478 ; GFX11-NEXT:    exp mrt0 v0, v1, v2, v3 done
479 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
480 ; GFX11-NEXT:    exp mrt0 v4, v5, v0, v0 done
481 ; GFX11-NEXT:    s_endpgm
482 main_body:
483   %a = shl i32 %inp, 6
484   %a1 = or i32 %a, 4
485   %a2 = or i32 %a, 8
486   %a3 = or i32 %a, 12
487   %a4 = or i32 %a, 16
488   %a5 = or i32 %a, 28
489   %a6 = or i32 %a, 32
490   %r1 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 %a1, i32 0, i32 0)
491   %r2 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 %a2, i32 0, i32 0)
492   %r3 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 %a3, i32 0, i32 0)
493   %r4 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 %a4, i32 0, i32 0)
494   %r5 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 %a5, i32 0, i32 0)
495   %r6 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 %a6, i32 0, i32 0)
496   call void @llvm.amdgcn.exp.f32(i32 0, i32 15, float %r1, float %r2, float %r3, float %r4, i1 true, i1 true)
497   call void @llvm.amdgcn.exp.f32(i32 0, i32 15, float %r5, float %r6, float undef, float undef, i1 true, i1 true)
498   ret void
501 define amdgpu_ps void @buffer_load_x1_offen_merged_glc_slc(ptr addrspace(8) inreg %rsrc, i32 %a) {
502 ; PREGFX10-LABEL: buffer_load_x1_offen_merged_glc_slc:
503 ; PREGFX10:       ; %bb.0: ; %main_body
504 ; PREGFX10-NEXT:    buffer_load_dwordx2 v[1:2], v0, s[0:3], 0 offen offset:4
505 ; PREGFX10-NEXT:    buffer_load_dwordx2 v[3:4], v0, s[0:3], 0 offen offset:12 glc
506 ; PREGFX10-NEXT:    buffer_load_dwordx2 v[5:6], v0, s[0:3], 0 offen offset:28 glc slc
507 ; PREGFX10-NEXT:    s_waitcnt vmcnt(1)
508 ; PREGFX10-NEXT:    exp mrt0 v1, v2, v3, v4 done vm
509 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
510 ; PREGFX10-NEXT:    exp mrt0 v5, v6, v0, v0 done vm
511 ; PREGFX10-NEXT:    s_endpgm
513 ; GFX10-LABEL: buffer_load_x1_offen_merged_glc_slc:
514 ; GFX10:       ; %bb.0: ; %main_body
515 ; GFX10-NEXT:    s_clause 0x2
516 ; GFX10-NEXT:    buffer_load_dwordx2 v[1:2], v0, s[0:3], 0 offen offset:4
517 ; GFX10-NEXT:    buffer_load_dwordx2 v[3:4], v0, s[0:3], 0 offen offset:12 glc
518 ; GFX10-NEXT:    buffer_load_dwordx2 v[5:6], v0, s[0:3], 0 offen offset:28 glc slc
519 ; GFX10-NEXT:    s_waitcnt vmcnt(1)
520 ; GFX10-NEXT:    exp mrt0 v1, v2, v3, v4 done vm
521 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
522 ; GFX10-NEXT:    exp mrt0 v5, v6, v0, v0 done vm
523 ; GFX10-NEXT:    s_endpgm
525 ; GFX11-LABEL: buffer_load_x1_offen_merged_glc_slc:
526 ; GFX11:       ; %bb.0: ; %main_body
527 ; GFX11-NEXT:    s_clause 0x2
528 ; GFX11-NEXT:    buffer_load_b64 v[1:2], v0, s[0:3], 0 offen offset:4
529 ; GFX11-NEXT:    buffer_load_b64 v[3:4], v0, s[0:3], 0 offen offset:12 glc
530 ; GFX11-NEXT:    buffer_load_b64 v[5:6], v0, s[0:3], 0 offen offset:28 glc slc
531 ; GFX11-NEXT:    s_waitcnt vmcnt(1)
532 ; GFX11-NEXT:    exp mrt0 v1, v2, v3, v4 done
533 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
534 ; GFX11-NEXT:    exp mrt0 v5, v6, v0, v0 done
535 ; GFX11-NEXT:    s_endpgm
536 main_body:
537   %a1 = add i32 %a, 4
538   %a2 = add i32 %a, 8
539   %a3 = add i32 %a, 12
540   %a4 = add i32 %a, 16
541   %a5 = add i32 %a, 28
542   %a6 = add i32 %a, 32
543   %r1 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 %a1, i32 0, i32 0)
544   %r2 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 %a2, i32 0, i32 0)
545   %r3 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 %a3, i32 0, i32 1)
546   %r4 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 %a4, i32 0, i32 1)
547   %r5 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 %a5, i32 0, i32 3)
548   %r6 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 %a6, i32 0, i32 3)
549   call void @llvm.amdgcn.exp.f32(i32 0, i32 15, float %r1, float %r2, float %r3, float %r4, i1 true, i1 true)
550   call void @llvm.amdgcn.exp.f32(i32 0, i32 15, float %r5, float %r6, float undef, float undef, i1 true, i1 true)
551   ret void
554 define amdgpu_ps void @buffer_load_x2_offen_merged_and(ptr addrspace(8) inreg %rsrc, i32 %a) {
555 ; PREGFX10-LABEL: buffer_load_x2_offen_merged_and:
556 ; PREGFX10:       ; %bb.0: ; %main_body
557 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[0:3], v0, s[0:3], 0 offen offset:4
558 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
559 ; PREGFX10-NEXT:    exp mrt0 v0, v1, v2, v3 done vm
560 ; PREGFX10-NEXT:    s_endpgm
562 ; GFX10-LABEL: buffer_load_x2_offen_merged_and:
563 ; GFX10:       ; %bb.0: ; %main_body
564 ; GFX10-NEXT:    buffer_load_dwordx4 v[0:3], v0, s[0:3], 0 offen offset:4
565 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
566 ; GFX10-NEXT:    exp mrt0 v0, v1, v2, v3 done vm
567 ; GFX10-NEXT:    s_endpgm
569 ; GFX11-LABEL: buffer_load_x2_offen_merged_and:
570 ; GFX11:       ; %bb.0: ; %main_body
571 ; GFX11-NEXT:    buffer_load_b128 v[0:3], v0, s[0:3], 0 offen offset:4
572 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
573 ; GFX11-NEXT:    exp mrt0 v0, v1, v2, v3 done
574 ; GFX11-NEXT:    s_endpgm
575 main_body:
576   %a1 = add i32 %a, 4
577   %a2 = add i32 %a, 12
578   %vr1 = call <2 x float> @llvm.amdgcn.raw.ptr.buffer.load.v2f32(ptr addrspace(8) %rsrc, i32 %a1, i32 0, i32 0)
579   %vr2 = call <2 x float> @llvm.amdgcn.raw.ptr.buffer.load.v2f32(ptr addrspace(8) %rsrc, i32 %a2, i32 0, i32 0)
580   %r1 = extractelement <2 x float> %vr1, i32 0
581   %r2 = extractelement <2 x float> %vr1, i32 1
582   %r3 = extractelement <2 x float> %vr2, i32 0
583   %r4 = extractelement <2 x float> %vr2, i32 1
584   call void @llvm.amdgcn.exp.f32(i32 0, i32 15, float %r1, float %r2, float %r3, float %r4, i1 true, i1 true)
585   ret void
588 define amdgpu_ps void @buffer_load_x2_offen_merged_or(ptr addrspace(8) inreg %rsrc, i32 %inp) {
589 ; PREGFX10-LABEL: buffer_load_x2_offen_merged_or:
590 ; PREGFX10:       ; %bb.0: ; %main_body
591 ; PREGFX10-NEXT:    v_lshlrev_b32_e32 v0, 4, v0
592 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[0:3], v0, s[0:3], 0 offen offset:4
593 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
594 ; PREGFX10-NEXT:    exp mrt0 v0, v1, v2, v3 done vm
595 ; PREGFX10-NEXT:    s_endpgm
597 ; GFX10-LABEL: buffer_load_x2_offen_merged_or:
598 ; GFX10:       ; %bb.0: ; %main_body
599 ; GFX10-NEXT:    v_lshlrev_b32_e32 v0, 4, v0
600 ; GFX10-NEXT:    buffer_load_dwordx4 v[0:3], v0, s[0:3], 0 offen offset:4
601 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
602 ; GFX10-NEXT:    exp mrt0 v0, v1, v2, v3 done vm
603 ; GFX10-NEXT:    s_endpgm
605 ; GFX11-LABEL: buffer_load_x2_offen_merged_or:
606 ; GFX11:       ; %bb.0: ; %main_body
607 ; GFX11-NEXT:    v_lshlrev_b32_e32 v0, 4, v0
608 ; GFX11-NEXT:    buffer_load_b128 v[0:3], v0, s[0:3], 0 offen offset:4
609 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
610 ; GFX11-NEXT:    exp mrt0 v0, v1, v2, v3 done
611 ; GFX11-NEXT:    s_endpgm
612 main_body:
613   %a = shl i32 %inp, 4
614   %a1 = add i32 %a, 4
615   %a2 = add i32 %a, 12
616   %vr1 = call <2 x float> @llvm.amdgcn.raw.ptr.buffer.load.v2f32(ptr addrspace(8) %rsrc, i32 %a1, i32 0, i32 0)
617   %vr2 = call <2 x float> @llvm.amdgcn.raw.ptr.buffer.load.v2f32(ptr addrspace(8) %rsrc, i32 %a2, i32 0, i32 0)
618   %r1 = extractelement <2 x float> %vr1, i32 0
619   %r2 = extractelement <2 x float> %vr1, i32 1
620   %r3 = extractelement <2 x float> %vr2, i32 0
621   %r4 = extractelement <2 x float> %vr2, i32 1
622   call void @llvm.amdgcn.exp.f32(i32 0, i32 15, float %r1, float %r2, float %r3, float %r4, i1 true, i1 true)
623   ret void
626 define amdgpu_ps void @buffer_load_x1_offset_merged(ptr addrspace(8) inreg %rsrc) {
627 ; PREGFX10-LABEL: buffer_load_x1_offset_merged:
628 ; PREGFX10:       ; %bb.0: ; %main_body
629 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[0:3], off, s[0:3], 0 offset:4
630 ; PREGFX10-NEXT:    buffer_load_dwordx2 v[4:5], off, s[0:3], 0 offset:28
631 ; PREGFX10-NEXT:    s_waitcnt vmcnt(1)
632 ; PREGFX10-NEXT:    exp mrt0 v0, v1, v2, v3 done vm
633 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
634 ; PREGFX10-NEXT:    exp mrt0 v4, v5, v0, v0 done vm
635 ; PREGFX10-NEXT:    s_endpgm
637 ; GFX10-LABEL: buffer_load_x1_offset_merged:
638 ; GFX10:       ; %bb.0: ; %main_body
639 ; GFX10-NEXT:    s_clause 0x1
640 ; GFX10-NEXT:    buffer_load_dwordx4 v[0:3], off, s[0:3], 0 offset:4
641 ; GFX10-NEXT:    buffer_load_dwordx2 v[4:5], off, s[0:3], 0 offset:28
642 ; GFX10-NEXT:    s_waitcnt vmcnt(1)
643 ; GFX10-NEXT:    exp mrt0 v0, v1, v2, v3 done vm
644 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
645 ; GFX10-NEXT:    exp mrt0 v4, v5, v0, v0 done vm
646 ; GFX10-NEXT:    s_endpgm
648 ; GFX11-LABEL: buffer_load_x1_offset_merged:
649 ; GFX11:       ; %bb.0: ; %main_body
650 ; GFX11-NEXT:    s_clause 0x1
651 ; GFX11-NEXT:    buffer_load_b128 v[0:3], off, s[0:3], 0 offset:4
652 ; GFX11-NEXT:    buffer_load_b64 v[4:5], off, s[0:3], 0 offset:28
653 ; GFX11-NEXT:    s_waitcnt vmcnt(1)
654 ; GFX11-NEXT:    exp mrt0 v0, v1, v2, v3 done
655 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
656 ; GFX11-NEXT:    exp mrt0 v4, v5, v0, v0 done
657 ; GFX11-NEXT:    s_endpgm
658 main_body:
659   %r1 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 4, i32 0, i32 0)
660   %r2 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 8, i32 0, i32 0)
661   %r3 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 12, i32 0, i32 0)
662   %r4 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 16, i32 0, i32 0)
663   %r5 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 28, i32 0, i32 0)
664   %r6 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 32, i32 0, i32 0)
665   call void @llvm.amdgcn.exp.f32(i32 0, i32 15, float %r1, float %r2, float %r3, float %r4, i1 true, i1 true)
666   call void @llvm.amdgcn.exp.f32(i32 0, i32 15, float %r5, float %r6, float undef, float undef, i1 true, i1 true)
667   ret void
670 define amdgpu_ps void @buffer_load_x2_offset_merged(ptr addrspace(8) inreg %rsrc) {
671 ; PREGFX10-LABEL: buffer_load_x2_offset_merged:
672 ; PREGFX10:       ; %bb.0: ; %main_body
673 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[0:3], off, s[0:3], 0 offset:4
674 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
675 ; PREGFX10-NEXT:    exp mrt0 v0, v1, v2, v3 done vm
676 ; PREGFX10-NEXT:    s_endpgm
678 ; GFX10-LABEL: buffer_load_x2_offset_merged:
679 ; GFX10:       ; %bb.0: ; %main_body
680 ; GFX10-NEXT:    buffer_load_dwordx4 v[0:3], off, s[0:3], 0 offset:4
681 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
682 ; GFX10-NEXT:    exp mrt0 v0, v1, v2, v3 done vm
683 ; GFX10-NEXT:    s_endpgm
685 ; GFX11-LABEL: buffer_load_x2_offset_merged:
686 ; GFX11:       ; %bb.0: ; %main_body
687 ; GFX11-NEXT:    buffer_load_b128 v[0:3], off, s[0:3], 0 offset:4
688 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
689 ; GFX11-NEXT:    exp mrt0 v0, v1, v2, v3 done
690 ; GFX11-NEXT:    s_endpgm
691 main_body:
692   %vr1 = call <2 x float> @llvm.amdgcn.raw.ptr.buffer.load.v2f32(ptr addrspace(8) %rsrc, i32 4, i32 0, i32 0)
693   %vr2 = call <2 x float> @llvm.amdgcn.raw.ptr.buffer.load.v2f32(ptr addrspace(8) %rsrc, i32 12, i32 0, i32 0)
694   %r1 = extractelement <2 x float> %vr1, i32 0
695   %r2 = extractelement <2 x float> %vr1, i32 1
696   %r3 = extractelement <2 x float> %vr2, i32 0
697   %r4 = extractelement <2 x float> %vr2, i32 1
698   call void @llvm.amdgcn.exp.f32(i32 0, i32 15, float %r1, float %r2, float %r3, float %r4, i1 true, i1 true)
699   ret void
702 define amdgpu_ps {<4 x float>, <2 x float>, float} @buffer_load_int(ptr addrspace(8) inreg) {
703 ; PREGFX10-LABEL: buffer_load_int:
704 ; PREGFX10:       ; %bb.0: ; %main_body
705 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[0:3], off, s[0:3], 0
706 ; PREGFX10-NEXT:    buffer_load_dwordx2 v[4:5], off, s[0:3], 0 glc
707 ; PREGFX10-NEXT:    buffer_load_dword v6, off, s[0:3], 0 slc
708 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
709 ; PREGFX10-NEXT:    ; return to shader part epilog
711 ; GFX10-LABEL: buffer_load_int:
712 ; GFX10:       ; %bb.0: ; %main_body
713 ; GFX10-NEXT:    s_clause 0x2
714 ; GFX10-NEXT:    buffer_load_dwordx4 v[0:3], off, s[0:3], 0
715 ; GFX10-NEXT:    buffer_load_dwordx2 v[4:5], off, s[0:3], 0 glc
716 ; GFX10-NEXT:    buffer_load_dword v6, off, s[0:3], 0 slc
717 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
718 ; GFX10-NEXT:    ; return to shader part epilog
720 ; GFX11-LABEL: buffer_load_int:
721 ; GFX11:       ; %bb.0: ; %main_body
722 ; GFX11-NEXT:    s_clause 0x2
723 ; GFX11-NEXT:    buffer_load_b128 v[0:3], off, s[0:3], 0
724 ; GFX11-NEXT:    buffer_load_b64 v[4:5], off, s[0:3], 0 glc
725 ; GFX11-NEXT:    buffer_load_b32 v6, off, s[0:3], 0 slc
726 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
727 ; GFX11-NEXT:    ; return to shader part epilog
728 main_body:
729   %data = call <4 x i32> @llvm.amdgcn.raw.ptr.buffer.load.v4i32(ptr addrspace(8) %0, i32 0, i32 0, i32 0)
730   %data_glc = call <2 x i32> @llvm.amdgcn.raw.ptr.buffer.load.v2i32(ptr addrspace(8) %0, i32 0, i32 0, i32 1)
731   %data_slc = call i32 @llvm.amdgcn.raw.ptr.buffer.load.i32(ptr addrspace(8) %0, i32 0, i32 0, i32 2)
732   %fdata = bitcast <4 x i32> %data to <4 x float>
733   %fdata_glc = bitcast <2 x i32> %data_glc to <2 x float>
734   %fdata_slc = bitcast i32 %data_slc to float
735   %r0 = insertvalue {<4 x float>, <2 x float>, float} undef, <4 x float> %fdata, 0
736   %r1 = insertvalue {<4 x float>, <2 x float>, float} %r0, <2 x float> %fdata_glc, 1
737   %r2 = insertvalue {<4 x float>, <2 x float>, float} %r1, float %fdata_slc, 2
738   ret {<4 x float>, <2 x float>, float} %r2
741 define amdgpu_ps float @raw_ptr_buffer_load_ubyte(ptr addrspace(8) inreg %rsrc) {
742 ; PREGFX10-LABEL: raw_ptr_buffer_load_ubyte:
743 ; PREGFX10:       ; %bb.0: ; %main_body
744 ; PREGFX10-NEXT:    buffer_load_ubyte v0, off, s[0:3], 0
745 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
746 ; PREGFX10-NEXT:    v_cvt_f32_ubyte0_e32 v0, v0
747 ; PREGFX10-NEXT:    ; return to shader part epilog
749 ; GFX10-LABEL: raw_ptr_buffer_load_ubyte:
750 ; GFX10:       ; %bb.0: ; %main_body
751 ; GFX10-NEXT:    buffer_load_ubyte v0, off, s[0:3], 0
752 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
753 ; GFX10-NEXT:    v_cvt_f32_ubyte0_e32 v0, v0
754 ; GFX10-NEXT:    ; return to shader part epilog
756 ; GFX11-LABEL: raw_ptr_buffer_load_ubyte:
757 ; GFX11:       ; %bb.0: ; %main_body
758 ; GFX11-NEXT:    buffer_load_u8 v0, off, s[0:3], 0
759 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
760 ; GFX11-NEXT:    v_cvt_f32_ubyte0_e32 v0, v0
761 ; GFX11-NEXT:    ; return to shader part epilog
762 main_body:
763   %tmp = call i8 @llvm.amdgcn.raw.ptr.buffer.load.i8(ptr addrspace(8) %rsrc, i32 0, i32 0, i32 0)
764   %tmp2 = zext i8 %tmp to i32
765   %val = uitofp i32 %tmp2 to float
766   ret float %val
769 define amdgpu_ps float @raw_ptr_buffer_load_i16(ptr addrspace(8) inreg %rsrc) {
770 ; PREGFX10-LABEL: raw_ptr_buffer_load_i16:
771 ; PREGFX10:       ; %bb.0: ; %main_body
772 ; PREGFX10-NEXT:    buffer_load_ushort v0, off, s[0:3], 0
773 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
774 ; PREGFX10-NEXT:    v_cvt_f32_u32_e32 v0, v0
775 ; PREGFX10-NEXT:    ; return to shader part epilog
777 ; GFX10-LABEL: raw_ptr_buffer_load_i16:
778 ; GFX10:       ; %bb.0: ; %main_body
779 ; GFX10-NEXT:    buffer_load_ushort v0, off, s[0:3], 0
780 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
781 ; GFX10-NEXT:    v_cvt_f32_u32_e32 v0, v0
782 ; GFX10-NEXT:    ; return to shader part epilog
784 ; GFX11-LABEL: raw_ptr_buffer_load_i16:
785 ; GFX11:       ; %bb.0: ; %main_body
786 ; GFX11-NEXT:    buffer_load_u16 v0, off, s[0:3], 0
787 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
788 ; GFX11-NEXT:    v_cvt_f32_u32_e32 v0, v0
789 ; GFX11-NEXT:    ; return to shader part epilog
790 main_body:
791   %tmp = call i16 @llvm.amdgcn.raw.ptr.buffer.load.i16(ptr addrspace(8) %rsrc, i32 0, i32 0, i32 0)
792   %tmp2 = zext i16 %tmp to i32
793   %val = uitofp i32 %tmp2 to float
794   ret float %val
797 define amdgpu_ps float @raw_ptr_buffer_load_sbyte(ptr addrspace(8) inreg %rsrc) {
798 ; PREGFX10-LABEL: raw_ptr_buffer_load_sbyte:
799 ; PREGFX10:       ; %bb.0: ; %main_body
800 ; PREGFX10-NEXT:    buffer_load_sbyte v0, off, s[0:3], 0
801 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
802 ; PREGFX10-NEXT:    v_cvt_f32_i32_e32 v0, v0
803 ; PREGFX10-NEXT:    ; return to shader part epilog
805 ; GFX10-LABEL: raw_ptr_buffer_load_sbyte:
806 ; GFX10:       ; %bb.0: ; %main_body
807 ; GFX10-NEXT:    buffer_load_sbyte v0, off, s[0:3], 0
808 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
809 ; GFX10-NEXT:    v_cvt_f32_i32_e32 v0, v0
810 ; GFX10-NEXT:    ; return to shader part epilog
812 ; GFX11-LABEL: raw_ptr_buffer_load_sbyte:
813 ; GFX11:       ; %bb.0: ; %main_body
814 ; GFX11-NEXT:    buffer_load_i8 v0, off, s[0:3], 0
815 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
816 ; GFX11-NEXT:    v_cvt_f32_i32_e32 v0, v0
817 ; GFX11-NEXT:    ; return to shader part epilog
818 main_body:
819   %tmp = call i8 @llvm.amdgcn.raw.ptr.buffer.load.i8(ptr addrspace(8) %rsrc, i32 0, i32 0, i32 0)
820   %tmp2 = sext i8 %tmp to i32
821   %val = sitofp i32 %tmp2 to float
822   ret float %val
825 define amdgpu_ps float @raw_ptr_buffer_load_sshort(ptr addrspace(8) inreg %rsrc) {
826 ; PREGFX10-LABEL: raw_ptr_buffer_load_sshort:
827 ; PREGFX10:       ; %bb.0: ; %main_body
828 ; PREGFX10-NEXT:    buffer_load_sshort v0, off, s[0:3], 0
829 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
830 ; PREGFX10-NEXT:    v_cvt_f32_i32_e32 v0, v0
831 ; PREGFX10-NEXT:    ; return to shader part epilog
833 ; GFX10-LABEL: raw_ptr_buffer_load_sshort:
834 ; GFX10:       ; %bb.0: ; %main_body
835 ; GFX10-NEXT:    buffer_load_sshort v0, off, s[0:3], 0
836 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
837 ; GFX10-NEXT:    v_cvt_f32_i32_e32 v0, v0
838 ; GFX10-NEXT:    ; return to shader part epilog
840 ; GFX11-LABEL: raw_ptr_buffer_load_sshort:
841 ; GFX11:       ; %bb.0: ; %main_body
842 ; GFX11-NEXT:    buffer_load_i16 v0, off, s[0:3], 0
843 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
844 ; GFX11-NEXT:    v_cvt_f32_i32_e32 v0, v0
845 ; GFX11-NEXT:    ; return to shader part epilog
846 main_body:
847   %tmp = call i16 @llvm.amdgcn.raw.ptr.buffer.load.i16(ptr addrspace(8) %rsrc, i32 0, i32 0, i32 0)
848   %tmp2 = sext i16 %tmp to i32
849   %val = sitofp i32 %tmp2 to float
850   ret float %val
853 define amdgpu_ps void @raw_ptr_buffer_load_f16(ptr addrspace(8) inreg %rsrc, ptr addrspace(3) %ptr) {
854 ; PREGFX10-LABEL: raw_ptr_buffer_load_f16:
855 ; PREGFX10:       ; %bb.0: ; %main_body
856 ; PREGFX10-NEXT:    buffer_load_ushort v1, off, s[0:3], 0
857 ; PREGFX10-NEXT:    s_mov_b32 m0, -1
858 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
859 ; PREGFX10-NEXT:    ds_write_b16 v0, v1
860 ; PREGFX10-NEXT:    s_endpgm
862 ; GFX10-LABEL: raw_ptr_buffer_load_f16:
863 ; GFX10:       ; %bb.0: ; %main_body
864 ; GFX10-NEXT:    buffer_load_ushort v1, off, s[0:3], 0
865 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
866 ; GFX10-NEXT:    ds_write_b16 v0, v1
867 ; GFX10-NEXT:    s_endpgm
869 ; GFX11-LABEL: raw_ptr_buffer_load_f16:
870 ; GFX11:       ; %bb.0: ; %main_body
871 ; GFX11-NEXT:    buffer_load_u16 v1, off, s[0:3], 0
872 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
873 ; GFX11-NEXT:    ds_store_b16 v0, v1
874 ; GFX11-NEXT:    s_endpgm
875 main_body:
876   %val = call half @llvm.amdgcn.raw.ptr.buffer.load.f16(ptr addrspace(8) %rsrc, i32 0, i32 0, i32 0)
877   store half %val, ptr addrspace(3) %ptr
878   ret void
881 define amdgpu_ps void @raw_ptr_buffer_load_v2f16(ptr addrspace(8) inreg %rsrc, ptr addrspace(3) %ptr) {
882 ; PREGFX10-LABEL: raw_ptr_buffer_load_v2f16:
883 ; PREGFX10:       ; %bb.0: ; %main_body
884 ; PREGFX10-NEXT:    buffer_load_dword v1, off, s[0:3], 0
885 ; PREGFX10-NEXT:    s_mov_b32 m0, -1
886 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
887 ; PREGFX10-NEXT:    ds_write_b32 v0, v1
888 ; PREGFX10-NEXT:    s_endpgm
890 ; GFX10-LABEL: raw_ptr_buffer_load_v2f16:
891 ; GFX10:       ; %bb.0: ; %main_body
892 ; GFX10-NEXT:    buffer_load_dword v1, off, s[0:3], 0
893 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
894 ; GFX10-NEXT:    ds_write_b32 v0, v1
895 ; GFX10-NEXT:    s_endpgm
897 ; GFX11-LABEL: raw_ptr_buffer_load_v2f16:
898 ; GFX11:       ; %bb.0: ; %main_body
899 ; GFX11-NEXT:    buffer_load_b32 v1, off, s[0:3], 0
900 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
901 ; GFX11-NEXT:    ds_store_b32 v0, v1
902 ; GFX11-NEXT:    s_endpgm
903 main_body:
904   %val = call <2 x half> @llvm.amdgcn.raw.ptr.buffer.load.v2f16(ptr addrspace(8) %rsrc, i32 0, i32 0, i32 0)
905   store <2 x half> %val, ptr addrspace(3) %ptr
906   ret void
909 define amdgpu_ps void @raw_ptr_buffer_load_v4f16(ptr addrspace(8) inreg %rsrc, ptr addrspace(3) %ptr) {
910 ; PREGFX10-LABEL: raw_ptr_buffer_load_v4f16:
911 ; PREGFX10:       ; %bb.0: ; %main_body
912 ; PREGFX10-NEXT:    buffer_load_dwordx2 v[1:2], off, s[0:3], 0
913 ; PREGFX10-NEXT:    s_mov_b32 m0, -1
914 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
915 ; PREGFX10-NEXT:    ds_write_b64 v0, v[1:2]
916 ; PREGFX10-NEXT:    s_endpgm
918 ; GFX10-LABEL: raw_ptr_buffer_load_v4f16:
919 ; GFX10:       ; %bb.0: ; %main_body
920 ; GFX10-NEXT:    buffer_load_dwordx2 v[1:2], off, s[0:3], 0
921 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
922 ; GFX10-NEXT:    ds_write_b64 v0, v[1:2]
923 ; GFX10-NEXT:    s_endpgm
925 ; GFX11-LABEL: raw_ptr_buffer_load_v4f16:
926 ; GFX11:       ; %bb.0: ; %main_body
927 ; GFX11-NEXT:    buffer_load_b64 v[1:2], off, s[0:3], 0
928 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
929 ; GFX11-NEXT:    ds_store_b64 v0, v[1:2]
930 ; GFX11-NEXT:    s_endpgm
931 main_body:
932   %val = call <4 x half> @llvm.amdgcn.raw.ptr.buffer.load.v4f16(ptr addrspace(8) %rsrc, i32 0, i32 0, i32 0)
933   store <4 x half> %val, ptr addrspace(3) %ptr
934   ret void
937 define amdgpu_ps void @raw_ptr_buffer_load_v2i16(ptr addrspace(8) inreg %rsrc, ptr addrspace(3) %ptr) {
938 ; PREGFX10-LABEL: raw_ptr_buffer_load_v2i16:
939 ; PREGFX10:       ; %bb.0: ; %main_body
940 ; PREGFX10-NEXT:    buffer_load_dword v1, off, s[0:3], 0
941 ; PREGFX10-NEXT:    s_mov_b32 m0, -1
942 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
943 ; PREGFX10-NEXT:    ds_write_b32 v0, v1
944 ; PREGFX10-NEXT:    s_endpgm
946 ; GFX10-LABEL: raw_ptr_buffer_load_v2i16:
947 ; GFX10:       ; %bb.0: ; %main_body
948 ; GFX10-NEXT:    buffer_load_dword v1, off, s[0:3], 0
949 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
950 ; GFX10-NEXT:    ds_write_b32 v0, v1
951 ; GFX10-NEXT:    s_endpgm
953 ; GFX11-LABEL: raw_ptr_buffer_load_v2i16:
954 ; GFX11:       ; %bb.0: ; %main_body
955 ; GFX11-NEXT:    buffer_load_b32 v1, off, s[0:3], 0
956 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
957 ; GFX11-NEXT:    ds_store_b32 v0, v1
958 ; GFX11-NEXT:    s_endpgm
959 main_body:
960   %val = call <2 x i16> @llvm.amdgcn.raw.ptr.buffer.load.v2i16(ptr addrspace(8) %rsrc, i32 0, i32 0, i32 0)
961   store <2 x i16> %val, ptr addrspace(3) %ptr
962   ret void
965 define amdgpu_ps void @raw_ptr_buffer_load_v4i16(ptr addrspace(8) inreg %rsrc, ptr addrspace(3) %ptr) {
966 ; PREGFX10-LABEL: raw_ptr_buffer_load_v4i16:
967 ; PREGFX10:       ; %bb.0: ; %main_body
968 ; PREGFX10-NEXT:    buffer_load_dwordx2 v[1:2], off, s[0:3], 0
969 ; PREGFX10-NEXT:    s_mov_b32 m0, -1
970 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
971 ; PREGFX10-NEXT:    ds_write_b64 v0, v[1:2]
972 ; PREGFX10-NEXT:    s_endpgm
974 ; GFX10-LABEL: raw_ptr_buffer_load_v4i16:
975 ; GFX10:       ; %bb.0: ; %main_body
976 ; GFX10-NEXT:    buffer_load_dwordx2 v[1:2], off, s[0:3], 0
977 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
978 ; GFX10-NEXT:    ds_write_b64 v0, v[1:2]
979 ; GFX10-NEXT:    s_endpgm
981 ; GFX11-LABEL: raw_ptr_buffer_load_v4i16:
982 ; GFX11:       ; %bb.0: ; %main_body
983 ; GFX11-NEXT:    buffer_load_b64 v[1:2], off, s[0:3], 0
984 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
985 ; GFX11-NEXT:    ds_store_b64 v0, v[1:2]
986 ; GFX11-NEXT:    s_endpgm
987 main_body:
988   %val = call <4 x i16> @llvm.amdgcn.raw.ptr.buffer.load.v4i16(ptr addrspace(8) %rsrc, i32 0, i32 0, i32 0)
989   store <4 x i16> %val, ptr addrspace(3) %ptr
990   ret void
993 define amdgpu_ps void @raw_ptr_buffer_load_x1_offset_merged(ptr addrspace(8) inreg %rsrc) {
994 ; PREGFX10-LABEL: raw_ptr_buffer_load_x1_offset_merged:
995 ; PREGFX10:       ; %bb.0: ; %main_body
996 ; PREGFX10-NEXT:    buffer_load_dwordx4 v[0:3], off, s[0:3], 0 offset:4
997 ; PREGFX10-NEXT:    buffer_load_dwordx2 v[4:5], off, s[0:3], 0 offset:28
998 ; PREGFX10-NEXT:    s_waitcnt vmcnt(1)
999 ; PREGFX10-NEXT:    exp mrt0 v0, v1, v2, v3 done vm
1000 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
1001 ; PREGFX10-NEXT:    exp mrt0 v4, v5, v0, v0 done vm
1002 ; PREGFX10-NEXT:    s_endpgm
1004 ; GFX10-LABEL: raw_ptr_buffer_load_x1_offset_merged:
1005 ; GFX10:       ; %bb.0: ; %main_body
1006 ; GFX10-NEXT:    s_clause 0x1
1007 ; GFX10-NEXT:    buffer_load_dwordx4 v[0:3], off, s[0:3], 0 offset:4
1008 ; GFX10-NEXT:    buffer_load_dwordx2 v[4:5], off, s[0:3], 0 offset:28
1009 ; GFX10-NEXT:    s_waitcnt vmcnt(1)
1010 ; GFX10-NEXT:    exp mrt0 v0, v1, v2, v3 done vm
1011 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
1012 ; GFX10-NEXT:    exp mrt0 v4, v5, v0, v0 done vm
1013 ; GFX10-NEXT:    s_endpgm
1015 ; GFX11-LABEL: raw_ptr_buffer_load_x1_offset_merged:
1016 ; GFX11:       ; %bb.0: ; %main_body
1017 ; GFX11-NEXT:    s_clause 0x1
1018 ; GFX11-NEXT:    buffer_load_b128 v[0:3], off, s[0:3], 0 offset:4
1019 ; GFX11-NEXT:    buffer_load_b64 v[4:5], off, s[0:3], 0 offset:28
1020 ; GFX11-NEXT:    s_waitcnt vmcnt(1)
1021 ; GFX11-NEXT:    exp mrt0 v0, v1, v2, v3 done
1022 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
1023 ; GFX11-NEXT:    exp mrt0 v4, v5, v0, v0 done
1024 ; GFX11-NEXT:    s_endpgm
1025 main_body:
1026   %r1 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 4, i32 0, i32 0)
1027   %r2 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 8, i32 0, i32 0)
1028   %r3 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 12, i32 0, i32 0)
1029   %r4 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 16, i32 0, i32 0)
1030   %r5 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 28, i32 0, i32 0)
1031   %r6 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 32, i32 0, i32 0)
1032   call void @llvm.amdgcn.exp.f32(i32 0, i32 15, float %r1, float %r2, float %r3, float %r4, i1 true, i1 true)
1033   call void @llvm.amdgcn.exp.f32(i32 0, i32 15, float %r5, float %r6, float undef, float undef, i1 true, i1 true)
1034   ret void
1037 define amdgpu_ps void @raw_ptr_buffer_load_x1_offset_swizzled_not_merged(ptr addrspace(8) inreg %rsrc) {
1038 ; PREGFX10-LABEL: raw_ptr_buffer_load_x1_offset_swizzled_not_merged:
1039 ; PREGFX10:       ; %bb.0: ; %main_body
1040 ; PREGFX10-NEXT:    buffer_load_dword v0, off, s[0:3], 0 offset:4
1041 ; PREGFX10-NEXT:    buffer_load_dword v1, off, s[0:3], 0 offset:8
1042 ; PREGFX10-NEXT:    buffer_load_dword v2, off, s[0:3], 0 offset:12
1043 ; PREGFX10-NEXT:    buffer_load_dword v3, off, s[0:3], 0 offset:16
1044 ; PREGFX10-NEXT:    buffer_load_dword v4, off, s[0:3], 0 offset:28
1045 ; PREGFX10-NEXT:    buffer_load_dword v5, off, s[0:3], 0 offset:32
1046 ; PREGFX10-NEXT:    s_waitcnt vmcnt(2)
1047 ; PREGFX10-NEXT:    exp mrt0 v0, v1, v2, v3 done vm
1048 ; PREGFX10-NEXT:    s_waitcnt vmcnt(0)
1049 ; PREGFX10-NEXT:    exp mrt0 v4, v5, v0, v0 done vm
1050 ; PREGFX10-NEXT:    s_endpgm
1052 ; GFX10-LABEL: raw_ptr_buffer_load_x1_offset_swizzled_not_merged:
1053 ; GFX10:       ; %bb.0: ; %main_body
1054 ; GFX10-NEXT:    s_clause 0x5
1055 ; GFX10-NEXT:    buffer_load_dword v0, off, s[0:3], 0 offset:4
1056 ; GFX10-NEXT:    buffer_load_dword v1, off, s[0:3], 0 offset:8
1057 ; GFX10-NEXT:    buffer_load_dword v2, off, s[0:3], 0 offset:12
1058 ; GFX10-NEXT:    buffer_load_dword v3, off, s[0:3], 0 offset:16
1059 ; GFX10-NEXT:    buffer_load_dword v4, off, s[0:3], 0 offset:28
1060 ; GFX10-NEXT:    buffer_load_dword v5, off, s[0:3], 0 offset:32
1061 ; GFX10-NEXT:    s_waitcnt vmcnt(2)
1062 ; GFX10-NEXT:    exp mrt0 v0, v1, v2, v3 done vm
1063 ; GFX10-NEXT:    s_waitcnt vmcnt(0)
1064 ; GFX10-NEXT:    exp mrt0 v4, v5, v0, v0 done vm
1065 ; GFX10-NEXT:    s_endpgm
1067 ; GFX11-LABEL: raw_ptr_buffer_load_x1_offset_swizzled_not_merged:
1068 ; GFX11:       ; %bb.0: ; %main_body
1069 ; GFX11-NEXT:    s_clause 0x5
1070 ; GFX11-NEXT:    buffer_load_b32 v0, off, s[0:3], 0 offset:4
1071 ; GFX11-NEXT:    buffer_load_b32 v1, off, s[0:3], 0 offset:8
1072 ; GFX11-NEXT:    buffer_load_b32 v2, off, s[0:3], 0 offset:12
1073 ; GFX11-NEXT:    buffer_load_b32 v3, off, s[0:3], 0 offset:16
1074 ; GFX11-NEXT:    buffer_load_b32 v4, off, s[0:3], 0 offset:28
1075 ; GFX11-NEXT:    buffer_load_b32 v5, off, s[0:3], 0 offset:32
1076 ; GFX11-NEXT:    s_waitcnt vmcnt(2)
1077 ; GFX11-NEXT:    exp mrt0 v0, v1, v2, v3 done
1078 ; GFX11-NEXT:    s_waitcnt vmcnt(0)
1079 ; GFX11-NEXT:    exp mrt0 v4, v5, v0, v0 done
1080 ; GFX11-NEXT:    s_endpgm
1081 main_body:
1082   %r1 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 4, i32 0, i32 8)
1083   %r2 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 8, i32 0, i32 8)
1084   %r3 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 12, i32 0, i32 8)
1085   %r4 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 16, i32 0, i32 8)
1086   %r5 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 28, i32 0, i32 8)
1087   %r6 = call float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8) %rsrc, i32 32, i32 0, i32 8)
1088   call void @llvm.amdgcn.exp.f32(i32 0, i32 15, float %r1, float %r2, float %r3, float %r4, i1 true, i1 true)
1089   call void @llvm.amdgcn.exp.f32(i32 0, i32 15, float %r5, float %r6, float undef, float undef, i1 true, i1 true)
1090   ret void
1093 declare float @llvm.amdgcn.raw.ptr.buffer.load.f32(ptr addrspace(8), i32, i32, i32) #0
1094 declare <2 x float> @llvm.amdgcn.raw.ptr.buffer.load.v2f32(ptr addrspace(8), i32, i32, i32) #0
1095 declare <4 x float> @llvm.amdgcn.raw.ptr.buffer.load.v4f32(ptr addrspace(8), i32, i32, i32) #0
1096 declare i32 @llvm.amdgcn.raw.ptr.buffer.load.i32(ptr addrspace(8), i32, i32, i32) #0
1097 declare <2 x i32> @llvm.amdgcn.raw.ptr.buffer.load.v2i32(ptr addrspace(8), i32, i32, i32) #0
1098 declare <4 x i32> @llvm.amdgcn.raw.ptr.buffer.load.v4i32(ptr addrspace(8), i32, i32, i32) #0
1099 declare void @llvm.amdgcn.exp.f32(i32, i32, float, float, float, float, i1, i1) #0
1100 declare i8 @llvm.amdgcn.raw.ptr.buffer.load.i8(ptr addrspace(8), i32, i32, i32) #0
1101 declare i16 @llvm.amdgcn.raw.ptr.buffer.load.i16(ptr addrspace(8), i32, i32, i32) #0
1102 declare <2 x i16> @llvm.amdgcn.raw.ptr.buffer.load.v2i16(ptr addrspace(8), i32, i32, i32) #0
1103 declare <4 x i16> @llvm.amdgcn.raw.ptr.buffer.load.v4i16(ptr addrspace(8), i32, i32, i32) #0
1104 declare half @llvm.amdgcn.raw.ptr.buffer.load.f16(ptr addrspace(8), i32, i32, i32) #0
1105 declare <2 x half> @llvm.amdgcn.raw.ptr.buffer.load.v2f16(ptr addrspace(8), i32, i32, i32) #0
1106 declare <4 x half> @llvm.amdgcn.raw.ptr.buffer.load.v4f16(ptr addrspace(8), i32, i32, i32) #0
1107 attributes #0 = { nounwind readonly }