[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / CodeGen / AMDGPU / GlobalISel / llvm.amdgcn.ds.fmin.ll
blob0f6fb5acd56adac37adfbda399e8731d38f183fb
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -global-isel -mtriple=amdgcn-mesa-mesa3d -mcpu=tonga -verify-machineinstrs < %s | FileCheck -enable-var-scope -check-prefix=GFX8 %s
3 ; RUN: llc -global-isel -mtriple=amdgcn-mesa-mesa3d -mcpu=gfx900 -verify-machineinstrs < %s | FileCheck -enable-var-scope -check-prefix=GFX9 %s
4 ; RUN: llc -global-isel -mtriple=amdgcn-mesa-mesa3d -mcpu=gfx1010 -verify-machineinstrs < %s | FileCheck -enable-var-scope -check-prefixes=GFX10PLUS,GFX10 %s
5 ; RUN: llc -global-isel -mtriple=amdgcn-mesa-mesa3d -mcpu=gfx1100 -amdgpu-enable-delay-alu=0 -verify-machineinstrs < %s | FileCheck -enable-var-scope -check-prefixes=GFX10PLUS,GFX11 %s
7 define amdgpu_ps float @ds_fmin_f32_ss(ptr addrspace(3) inreg %ptr, float inreg %val) {
8 ; GFX8-LABEL: ds_fmin_f32_ss:
9 ; GFX8:       ; %bb.0:
10 ; GFX8-NEXT:    v_mov_b32_e32 v0, s2
11 ; GFX8-NEXT:    v_mov_b32_e32 v1, s3
12 ; GFX8-NEXT:    s_mov_b32 m0, -1
13 ; GFX8-NEXT:    ds_min_rtn_f32 v0, v0, v1
14 ; GFX8-NEXT:    s_waitcnt lgkmcnt(0)
15 ; GFX8-NEXT:    ; return to shader part epilog
17 ; GFX9-LABEL: ds_fmin_f32_ss:
18 ; GFX9:       ; %bb.0:
19 ; GFX9-NEXT:    v_mov_b32_e32 v0, s2
20 ; GFX9-NEXT:    v_mov_b32_e32 v1, s3
21 ; GFX9-NEXT:    ds_min_rtn_f32 v0, v0, v1
22 ; GFX9-NEXT:    s_waitcnt lgkmcnt(0)
23 ; GFX9-NEXT:    ; return to shader part epilog
25 ; GFX10-LABEL: ds_fmin_f32_ss:
26 ; GFX10:       ; %bb.0:
27 ; GFX10-NEXT:    v_mov_b32_e32 v0, s2
28 ; GFX10-NEXT:    v_mov_b32_e32 v1, s3
29 ; GFX10-NEXT:    ds_min_rtn_f32 v0, v0, v1
30 ; GFX10-NEXT:    s_waitcnt lgkmcnt(0)
31 ; GFX10-NEXT:    ; return to shader part epilog
33 ; GFX11-LABEL: ds_fmin_f32_ss:
34 ; GFX11:       ; %bb.0:
35 ; GFX11-NEXT:    v_dual_mov_b32 v0, s2 :: v_dual_mov_b32 v1, s3
36 ; GFX11-NEXT:    ds_min_rtn_f32 v0, v0, v1
37 ; GFX11-NEXT:    s_waitcnt lgkmcnt(0)
38 ; GFX11-NEXT:    ; return to shader part epilog
39   %ret = call float @llvm.amdgcn.ds.fmin(ptr addrspace(3) %ptr, float %val, i32 0, i32 0, i1 false)
40   ret float %ret
43 define amdgpu_ps float @ds_fmin_f32_ss_offset(ptr addrspace(3) inreg %ptr, float inreg %val) {
44 ; GFX8-LABEL: ds_fmin_f32_ss_offset:
45 ; GFX8:       ; %bb.0:
46 ; GFX8-NEXT:    v_mov_b32_e32 v0, s3
47 ; GFX8-NEXT:    v_mov_b32_e32 v1, s2
48 ; GFX8-NEXT:    s_mov_b32 m0, -1
49 ; GFX8-NEXT:    ds_min_rtn_f32 v0, v1, v0 offset:512
50 ; GFX8-NEXT:    s_waitcnt lgkmcnt(0)
51 ; GFX8-NEXT:    ; return to shader part epilog
53 ; GFX9-LABEL: ds_fmin_f32_ss_offset:
54 ; GFX9:       ; %bb.0:
55 ; GFX9-NEXT:    v_mov_b32_e32 v0, s3
56 ; GFX9-NEXT:    v_mov_b32_e32 v1, s2
57 ; GFX9-NEXT:    ds_min_rtn_f32 v0, v1, v0 offset:512
58 ; GFX9-NEXT:    s_waitcnt lgkmcnt(0)
59 ; GFX9-NEXT:    ; return to shader part epilog
61 ; GFX10-LABEL: ds_fmin_f32_ss_offset:
62 ; GFX10:       ; %bb.0:
63 ; GFX10-NEXT:    v_mov_b32_e32 v0, s3
64 ; GFX10-NEXT:    v_mov_b32_e32 v1, s2
65 ; GFX10-NEXT:    ds_min_rtn_f32 v0, v1, v0 offset:512
66 ; GFX10-NEXT:    s_waitcnt lgkmcnt(0)
67 ; GFX10-NEXT:    ; return to shader part epilog
69 ; GFX11-LABEL: ds_fmin_f32_ss_offset:
70 ; GFX11:       ; %bb.0:
71 ; GFX11-NEXT:    v_dual_mov_b32 v0, s3 :: v_dual_mov_b32 v1, s2
72 ; GFX11-NEXT:    ds_min_rtn_f32 v0, v1, v0 offset:512
73 ; GFX11-NEXT:    s_waitcnt lgkmcnt(0)
74 ; GFX11-NEXT:    ; return to shader part epilog
75   %gep = getelementptr float, ptr addrspace(3) %ptr, i32 128
76   %ret = call float @llvm.amdgcn.ds.fmin(ptr addrspace(3) %gep, float %val, i32 0, i32 0, i1 false)
77   ret float %ret
80 define amdgpu_ps void @ds_fmin_f32_ss_nortn(ptr addrspace(3) inreg %ptr, float inreg %val) {
81 ; GFX8-LABEL: ds_fmin_f32_ss_nortn:
82 ; GFX8:       ; %bb.0:
83 ; GFX8-NEXT:    v_mov_b32_e32 v0, s2
84 ; GFX8-NEXT:    v_mov_b32_e32 v1, s3
85 ; GFX8-NEXT:    s_mov_b32 m0, -1
86 ; GFX8-NEXT:    ds_min_f32 v0, v1
87 ; GFX8-NEXT:    s_endpgm
89 ; GFX9-LABEL: ds_fmin_f32_ss_nortn:
90 ; GFX9:       ; %bb.0:
91 ; GFX9-NEXT:    v_mov_b32_e32 v0, s2
92 ; GFX9-NEXT:    v_mov_b32_e32 v1, s3
93 ; GFX9-NEXT:    ds_min_f32 v0, v1
94 ; GFX9-NEXT:    s_endpgm
96 ; GFX10-LABEL: ds_fmin_f32_ss_nortn:
97 ; GFX10:       ; %bb.0:
98 ; GFX10-NEXT:    v_mov_b32_e32 v0, s2
99 ; GFX10-NEXT:    v_mov_b32_e32 v1, s3
100 ; GFX10-NEXT:    ds_min_f32 v0, v1
101 ; GFX10-NEXT:    s_endpgm
103 ; GFX11-LABEL: ds_fmin_f32_ss_nortn:
104 ; GFX11:       ; %bb.0:
105 ; GFX11-NEXT:    v_dual_mov_b32 v0, s2 :: v_dual_mov_b32 v1, s3
106 ; GFX11-NEXT:    ds_min_f32 v0, v1
107 ; GFX11-NEXT:    s_endpgm
108   %unused = call float @llvm.amdgcn.ds.fmin(ptr addrspace(3) %ptr, float %val, i32 0, i32 0, i1 false)
109   ret void
112 define amdgpu_ps void @ds_fmin_f32_ss_offset_nortn(ptr addrspace(3) inreg %ptr, float inreg %val) {
113 ; GFX8-LABEL: ds_fmin_f32_ss_offset_nortn:
114 ; GFX8:       ; %bb.0:
115 ; GFX8-NEXT:    v_mov_b32_e32 v0, s3
116 ; GFX8-NEXT:    v_mov_b32_e32 v1, s2
117 ; GFX8-NEXT:    s_mov_b32 m0, -1
118 ; GFX8-NEXT:    ds_min_f32 v1, v0 offset:512
119 ; GFX8-NEXT:    s_endpgm
121 ; GFX9-LABEL: ds_fmin_f32_ss_offset_nortn:
122 ; GFX9:       ; %bb.0:
123 ; GFX9-NEXT:    v_mov_b32_e32 v0, s3
124 ; GFX9-NEXT:    v_mov_b32_e32 v1, s2
125 ; GFX9-NEXT:    ds_min_f32 v1, v0 offset:512
126 ; GFX9-NEXT:    s_endpgm
128 ; GFX10-LABEL: ds_fmin_f32_ss_offset_nortn:
129 ; GFX10:       ; %bb.0:
130 ; GFX10-NEXT:    v_mov_b32_e32 v0, s3
131 ; GFX10-NEXT:    v_mov_b32_e32 v1, s2
132 ; GFX10-NEXT:    ds_min_f32 v1, v0 offset:512
133 ; GFX10-NEXT:    s_endpgm
135 ; GFX11-LABEL: ds_fmin_f32_ss_offset_nortn:
136 ; GFX11:       ; %bb.0:
137 ; GFX11-NEXT:    v_dual_mov_b32 v0, s3 :: v_dual_mov_b32 v1, s2
138 ; GFX11-NEXT:    ds_min_f32 v1, v0 offset:512
139 ; GFX11-NEXT:    s_endpgm
140   %gep = getelementptr float, ptr addrspace(3) %ptr, i32 128
141   %unused = call float @llvm.amdgcn.ds.fmin(ptr addrspace(3) %gep, float %val, i32 0, i32 0, i1 false)
142   ret void
145 define float @ds_fmin_f32_vv(ptr addrspace(3) %ptr, float %val) {
146 ; GFX8-LABEL: ds_fmin_f32_vv:
147 ; GFX8:       ; %bb.0:
148 ; GFX8-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
149 ; GFX8-NEXT:    s_mov_b32 m0, -1
150 ; GFX8-NEXT:    ds_min_rtn_f32 v0, v0, v1
151 ; GFX8-NEXT:    s_waitcnt lgkmcnt(0)
152 ; GFX8-NEXT:    s_setpc_b64 s[30:31]
154 ; GFX9-LABEL: ds_fmin_f32_vv:
155 ; GFX9:       ; %bb.0:
156 ; GFX9-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
157 ; GFX9-NEXT:    ds_min_rtn_f32 v0, v0, v1
158 ; GFX9-NEXT:    s_waitcnt lgkmcnt(0)
159 ; GFX9-NEXT:    s_setpc_b64 s[30:31]
161 ; GFX10PLUS-LABEL: ds_fmin_f32_vv:
162 ; GFX10PLUS:       ; %bb.0:
163 ; GFX10PLUS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
164 ; GFX10PLUS-NEXT:    ds_min_rtn_f32 v0, v0, v1
165 ; GFX10PLUS-NEXT:    s_waitcnt lgkmcnt(0)
166 ; GFX10PLUS-NEXT:    s_setpc_b64 s[30:31]
167   %ret = call float @llvm.amdgcn.ds.fmin(ptr addrspace(3) %ptr, float %val, i32 0, i32 0, i1 false)
168   ret float %ret
171 define float @ds_fmin_f32_vv_offset(ptr addrspace(3) %ptr, float %val) {
172 ; GFX8-LABEL: ds_fmin_f32_vv_offset:
173 ; GFX8:       ; %bb.0:
174 ; GFX8-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
175 ; GFX8-NEXT:    s_mov_b32 m0, -1
176 ; GFX8-NEXT:    ds_min_rtn_f32 v0, v0, v1 offset:512
177 ; GFX8-NEXT:    s_waitcnt lgkmcnt(0)
178 ; GFX8-NEXT:    s_setpc_b64 s[30:31]
180 ; GFX9-LABEL: ds_fmin_f32_vv_offset:
181 ; GFX9:       ; %bb.0:
182 ; GFX9-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
183 ; GFX9-NEXT:    ds_min_rtn_f32 v0, v0, v1 offset:512
184 ; GFX9-NEXT:    s_waitcnt lgkmcnt(0)
185 ; GFX9-NEXT:    s_setpc_b64 s[30:31]
187 ; GFX10PLUS-LABEL: ds_fmin_f32_vv_offset:
188 ; GFX10PLUS:       ; %bb.0:
189 ; GFX10PLUS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
190 ; GFX10PLUS-NEXT:    ds_min_rtn_f32 v0, v0, v1 offset:512
191 ; GFX10PLUS-NEXT:    s_waitcnt lgkmcnt(0)
192 ; GFX10PLUS-NEXT:    s_setpc_b64 s[30:31]
193   %gep = getelementptr float, ptr addrspace(3) %ptr, i32 128
194   %ret = call float @llvm.amdgcn.ds.fmin(ptr addrspace(3) %gep, float %val, i32 0, i32 0, i1 false)
195   ret float %ret
198 define void @ds_fmin_f32_vv_nortn(ptr addrspace(3) %ptr, float %val) {
199 ; GFX8-LABEL: ds_fmin_f32_vv_nortn:
200 ; GFX8:       ; %bb.0:
201 ; GFX8-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
202 ; GFX8-NEXT:    s_mov_b32 m0, -1
203 ; GFX8-NEXT:    ds_min_f32 v0, v1
204 ; GFX8-NEXT:    s_waitcnt lgkmcnt(0)
205 ; GFX8-NEXT:    s_setpc_b64 s[30:31]
207 ; GFX9-LABEL: ds_fmin_f32_vv_nortn:
208 ; GFX9:       ; %bb.0:
209 ; GFX9-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
210 ; GFX9-NEXT:    ds_min_f32 v0, v1
211 ; GFX9-NEXT:    s_waitcnt lgkmcnt(0)
212 ; GFX9-NEXT:    s_setpc_b64 s[30:31]
214 ; GFX10PLUS-LABEL: ds_fmin_f32_vv_nortn:
215 ; GFX10PLUS:       ; %bb.0:
216 ; GFX10PLUS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
217 ; GFX10PLUS-NEXT:    ds_min_f32 v0, v1
218 ; GFX10PLUS-NEXT:    s_waitcnt lgkmcnt(0)
219 ; GFX10PLUS-NEXT:    s_setpc_b64 s[30:31]
220   %ret = call float @llvm.amdgcn.ds.fmin(ptr addrspace(3) %ptr, float %val, i32 0, i32 0, i1 false)
221   ret void
224 define void @ds_fmin_f32_vv_offset_nortn(ptr addrspace(3) %ptr, float %val) {
225 ; GFX8-LABEL: ds_fmin_f32_vv_offset_nortn:
226 ; GFX8:       ; %bb.0:
227 ; GFX8-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
228 ; GFX8-NEXT:    s_mov_b32 m0, -1
229 ; GFX8-NEXT:    ds_min_f32 v0, v1 offset:512
230 ; GFX8-NEXT:    s_waitcnt lgkmcnt(0)
231 ; GFX8-NEXT:    s_setpc_b64 s[30:31]
233 ; GFX9-LABEL: ds_fmin_f32_vv_offset_nortn:
234 ; GFX9:       ; %bb.0:
235 ; GFX9-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
236 ; GFX9-NEXT:    ds_min_f32 v0, v1 offset:512
237 ; GFX9-NEXT:    s_waitcnt lgkmcnt(0)
238 ; GFX9-NEXT:    s_setpc_b64 s[30:31]
240 ; GFX10PLUS-LABEL: ds_fmin_f32_vv_offset_nortn:
241 ; GFX10PLUS:       ; %bb.0:
242 ; GFX10PLUS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
243 ; GFX10PLUS-NEXT:    ds_min_f32 v0, v1 offset:512
244 ; GFX10PLUS-NEXT:    s_waitcnt lgkmcnt(0)
245 ; GFX10PLUS-NEXT:    s_setpc_b64 s[30:31]
246   %gep = getelementptr float, ptr addrspace(3) %ptr, i32 128
247   %ret = call float @llvm.amdgcn.ds.fmin(ptr addrspace(3) %gep, float %val, i32 0, i32 0, i1 false)
248   ret void
251 define float @ds_fmin_f32_vv_volatile(ptr addrspace(3) %ptr, float %val) {
252 ; GFX8-LABEL: ds_fmin_f32_vv_volatile:
253 ; GFX8:       ; %bb.0:
254 ; GFX8-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
255 ; GFX8-NEXT:    s_mov_b32 m0, -1
256 ; GFX8-NEXT:    ds_min_rtn_f32 v0, v0, v1
257 ; GFX8-NEXT:    s_waitcnt lgkmcnt(0)
258 ; GFX8-NEXT:    s_setpc_b64 s[30:31]
260 ; GFX9-LABEL: ds_fmin_f32_vv_volatile:
261 ; GFX9:       ; %bb.0:
262 ; GFX9-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
263 ; GFX9-NEXT:    ds_min_rtn_f32 v0, v0, v1
264 ; GFX9-NEXT:    s_waitcnt lgkmcnt(0)
265 ; GFX9-NEXT:    s_setpc_b64 s[30:31]
267 ; GFX10PLUS-LABEL: ds_fmin_f32_vv_volatile:
268 ; GFX10PLUS:       ; %bb.0:
269 ; GFX10PLUS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
270 ; GFX10PLUS-NEXT:    ds_min_rtn_f32 v0, v0, v1
271 ; GFX10PLUS-NEXT:    s_waitcnt lgkmcnt(0)
272 ; GFX10PLUS-NEXT:    s_setpc_b64 s[30:31]
273   %ret = call float @llvm.amdgcn.ds.fmin(ptr addrspace(3) %ptr, float %val, i32 0, i32 0, i1 true)
274   ret float %ret
277 declare float @llvm.amdgcn.ds.fmin(ptr addrspace(3) nocapture, float, i32 immarg, i32 immarg, i1 immarg) #0
279 attributes #0 = { argmemonly nounwind willreturn }