blob: 9b977fc5463066e4d075f233cd439f4fba29905d [file] [log] [blame]
Matt Arsenaultf639c322016-01-28 20:53:42 +00001; RUN: llc -march=amdgcn -verify-machineinstrs < %s | FileCheck -check-prefix=GCN %s
2; RUN: llc -march=amdgcn -mcpu=tonga -verify-machineinstrs < %s | FileCheck -check-prefix=GCN %s
3
4declare i32 @llvm.r600.read.tidig.x() #0
5
6; GCN-LABEL: {{^}}v_test_smed3_r_i_i_i32:
7; GCN: v_med3_i32 v{{[0-9]+}}, v{{[0-9]+}}, 12, 17
8define void @v_test_smed3_r_i_i_i32(i32 addrspace(1)* %out, i32 addrspace(1)* %aptr) #1 {
9 %tid = call i32 @llvm.r600.read.tidig.x()
10 %gep0 = getelementptr i32, i32 addrspace(1)* %aptr, i32 %tid
11 %outgep = getelementptr i32, i32 addrspace(1)* %out, i32 %tid
12 %a = load i32, i32 addrspace(1)* %gep0
13
14 %icmp0 = icmp sgt i32 %a, 12
15 %i0 = select i1 %icmp0, i32 %a, i32 12
16
17 %icmp1 = icmp slt i32 %i0, 17
18 %i1 = select i1 %icmp1, i32 %i0, i32 17
19
20 store i32 %i1, i32 addrspace(1)* %outgep
21 ret void
22}
23
24; GCN-LABEL: {{^}}v_test_smed3_multi_use_r_i_i_i32:
25; GCN: v_max_i32
26; GCN: v_min_i32
27define void @v_test_smed3_multi_use_r_i_i_i32(i32 addrspace(1)* %out, i32 addrspace(1)* %aptr) #1 {
28 %tid = call i32 @llvm.r600.read.tidig.x()
29 %gep0 = getelementptr i32, i32 addrspace(1)* %aptr, i32 %tid
30 %outgep = getelementptr i32, i32 addrspace(1)* %out, i32 %tid
31 %a = load i32, i32 addrspace(1)* %gep0
32
33 %icmp0 = icmp sgt i32 %a, 12
34 %i0 = select i1 %icmp0, i32 %a, i32 12
35
36 %icmp1 = icmp slt i32 %i0, 17
37 %i1 = select i1 %icmp1, i32 %i0, i32 17
38
39 store volatile i32 %i0, i32 addrspace(1)* %outgep
40 store volatile i32 %i1, i32 addrspace(1)* %outgep
41 ret void
42}
43
44; GCN-LABEL: {{^}}v_test_smed3_r_i_i_constant_order_i32:
45; GCN: v_max_i32_e32 v{{[0-9]+}}, 17, v{{[0-9]+}}
46; GCN: v_min_i32_e32 v{{[0-9]+}}, 12, v{{[0-9]+}}
47define void @v_test_smed3_r_i_i_constant_order_i32(i32 addrspace(1)* %out, i32 addrspace(1)* %aptr) #1 {
48 %tid = call i32 @llvm.r600.read.tidig.x()
49 %gep0 = getelementptr i32, i32 addrspace(1)* %aptr, i32 %tid
50 %outgep = getelementptr i32, i32 addrspace(1)* %out, i32 %tid
51 %a = load i32, i32 addrspace(1)* %gep0
52
53 %icmp0 = icmp sgt i32 %a, 17
54 %i0 = select i1 %icmp0, i32 %a, i32 17
55
56 %icmp1 = icmp slt i32 %i0, 12
57 %i1 = select i1 %icmp1, i32 %i0, i32 12
58
59 store i32 %i1, i32 addrspace(1)* %outgep
60 ret void
61}
62
63; GCN-LABEL: {{^}}v_test_smed3_r_i_i_sign_mismatch_i32:
64; GCN: v_max_u32_e32 v{{[0-9]+}}, 12, v{{[0-9]+}}
65; GCN: v_min_i32_e32 v{{[0-9]+}}, 17, v{{[0-9]+}}
66define void @v_test_smed3_r_i_i_sign_mismatch_i32(i32 addrspace(1)* %out, i32 addrspace(1)* %aptr) #1 {
67 %tid = call i32 @llvm.r600.read.tidig.x()
68 %gep0 = getelementptr i32, i32 addrspace(1)* %aptr, i32 %tid
69 %outgep = getelementptr i32, i32 addrspace(1)* %out, i32 %tid
70 %a = load i32, i32 addrspace(1)* %gep0
71
72 %icmp0 = icmp ugt i32 %a, 12
73 %i0 = select i1 %icmp0, i32 %a, i32 12
74
75 %icmp1 = icmp slt i32 %i0, 17
76 %i1 = select i1 %icmp1, i32 %i0, i32 17
77
78 store i32 %i1, i32 addrspace(1)* %outgep
79 ret void
80}
81
82; GCN-LABEL: {{^}}v_test_smed3_r_i_i_i64:
83; GCN: v_cmp_lt_i64
84; GCN: v_cmp_gt_i64
85define void @v_test_smed3_r_i_i_i64(i64 addrspace(1)* %out, i64 addrspace(1)* %aptr) #1 {
86 %tid = call i32 @llvm.r600.read.tidig.x()
87 %gep0 = getelementptr i64, i64 addrspace(1)* %aptr, i32 %tid
88 %outgep = getelementptr i64, i64 addrspace(1)* %out, i32 %tid
89 %a = load i64, i64 addrspace(1)* %gep0
90
91 %icmp0 = icmp sgt i64 %a, 12
92 %i0 = select i1 %icmp0, i64 %a, i64 12
93
94 %icmp1 = icmp slt i64 %i0, 17
95 %i1 = select i1 %icmp1, i64 %i0, i64 17
96
97 store i64 %i1, i64 addrspace(1)* %outgep
98 ret void
99}
100
101; GCN-LABEL: {{^}}v_test_smed3_r_i_i_i16:
102; GCN: v_med3_i32 v{{[0-9]+}}, v{{[0-9]+}}, 12, 17
103define void @v_test_smed3_r_i_i_i16(i16 addrspace(1)* %out, i16 addrspace(1)* %aptr) #1 {
104 %tid = call i32 @llvm.r600.read.tidig.x()
105 %gep0 = getelementptr i16, i16 addrspace(1)* %aptr, i32 %tid
106 %outgep = getelementptr i16, i16 addrspace(1)* %out, i32 %tid
107 %a = load i16, i16 addrspace(1)* %gep0
108
109 %icmp0 = icmp sgt i16 %a, 12
110 %i0 = select i1 %icmp0, i16 %a, i16 12
111
112 %icmp1 = icmp slt i16 %i0, 17
113 %i1 = select i1 %icmp1, i16 %i0, i16 17
114
115 store i16 %i1, i16 addrspace(1)* %outgep
116 ret void
117}
118
Matt Arsenaultc89f2912016-03-07 21:54:48 +0000119
120define internal i32 @smin(i32 %x, i32 %y) #2 {
121 %cmp = icmp slt i32 %x, %y
122 %sel = select i1 %cmp, i32 %x, i32 %y
123 ret i32 %sel
124}
125
126define internal i32 @smax(i32 %x, i32 %y) #2 {
127 %cmp = icmp sgt i32 %x, %y
128 %sel = select i1 %cmp, i32 %x, i32 %y
129 ret i32 %sel
130}
131
132define internal i16 @smin16(i16 %x, i16 %y) #2 {
133 %cmp = icmp slt i16 %x, %y
134 %sel = select i1 %cmp, i16 %x, i16 %y
135 ret i16 %sel
136}
137
138define internal i16 @smax16(i16 %x, i16 %y) #2 {
139 %cmp = icmp sgt i16 %x, %y
140 %sel = select i1 %cmp, i16 %x, i16 %y
141 ret i16 %sel
142}
143
144define internal i8 @smin8(i8 %x, i8 %y) #2 {
145 %cmp = icmp slt i8 %x, %y
146 %sel = select i1 %cmp, i8 %x, i8 %y
147 ret i8 %sel
148}
149
150define internal i8 @smax8(i8 %x, i8 %y) #2 {
151 %cmp = icmp sgt i8 %x, %y
152 %sel = select i1 %cmp, i8 %x, i8 %y
153 ret i8 %sel
154}
155
156; 16 combinations
157
158; 0: max(min(x, y), min(max(x, y), z))
159; 1: max(min(x, y), min(max(y, x), z))
160; 2: max(min(x, y), min(z, max(x, y)))
161; 3: max(min(x, y), min(z, max(y, x)))
162; 4: max(min(y, x), min(max(x, y), z))
163; 5: max(min(y, x), min(max(y, x), z))
164; 6: max(min(y, x), min(z, max(x, y)))
165; 7: max(min(y, x), min(z, max(y, x)))
166;
167; + commute outermost max
168
169
170; FIXME: In these cases we probably should have used scalar operations
171; instead.
172
173; GCN-LABEL: {{^}}s_test_smed3_i32_pat_0:
174; GCN: v_med3_i32 v{{[0-9]+}}, s{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
175define void @s_test_smed3_i32_pat_0(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
176bb:
177 %tmp0 = call i32 @smin(i32 %x, i32 %y)
178 %tmp1 = call i32 @smax(i32 %x, i32 %y)
179 %tmp2 = call i32 @smin(i32 %tmp1, i32 %z)
180 %tmp3 = call i32 @smax(i32 %tmp0, i32 %tmp2)
181 store i32 %tmp3, i32 addrspace(1)* %arg
182 ret void
183}
184
185; GCN-LABEL: {{^}}s_test_smed3_i32_pat_1:
186; GCN: v_med3_i32 v{{[0-9]+}}, s{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
187define void @s_test_smed3_i32_pat_1(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
188bb:
189 %tmp0 = call i32 @smin(i32 %x, i32 %y)
190 %tmp1 = call i32 @smax(i32 %y, i32 %x)
191 %tmp2 = call i32 @smin(i32 %tmp1, i32 %z)
192 %tmp3 = call i32 @smax(i32 %tmp0, i32 %tmp2)
193 store i32 %tmp3, i32 addrspace(1)* %arg
194 ret void
195}
196
197; GCN-LABEL: {{^}}s_test_smed3_i32_pat_2:
198; GCN: v_med3_i32 v{{[0-9]+}}, s{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
199define void @s_test_smed3_i32_pat_2(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
200bb:
201 %tmp0 = call i32 @smin(i32 %x, i32 %y)
202 %tmp1 = call i32 @smax(i32 %x, i32 %y)
203 %tmp2 = call i32 @smin(i32 %z, i32 %tmp1)
204 %tmp3 = call i32 @smax(i32 %tmp0, i32 %tmp2)
205 store i32 %tmp3, i32 addrspace(1)* %arg
206 ret void
207}
208
209; GCN-LABEL: {{^}}s_test_smed3_i32_pat_3:
210; GCN: v_med3_i32 v{{[0-9]+}}, s{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
211define void @s_test_smed3_i32_pat_3(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
212bb:
213 %tmp0 = call i32 @smin(i32 %x, i32 %y)
214 %tmp1 = call i32 @smax(i32 %y, i32 %x)
215 %tmp2 = call i32 @smin(i32 %z, i32 %tmp1)
216 %tmp3 = call i32 @smax(i32 %tmp0, i32 %tmp2)
217 store i32 %tmp3, i32 addrspace(1)* %arg
218 ret void
219}
220
221; GCN-LABEL: {{^}}s_test_smed3_i32_pat_4:
222; GCN: v_med3_i32 v{{[0-9]+}}, s{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
223define void @s_test_smed3_i32_pat_4(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
224bb:
225 %tmp0 = call i32 @smin(i32 %y, i32 %x)
226 %tmp1 = call i32 @smax(i32 %x, i32 %y)
227 %tmp2 = call i32 @smin(i32 %tmp1, i32 %z)
228 %tmp3 = call i32 @smax(i32 %tmp0, i32 %tmp2)
229 store i32 %tmp3, i32 addrspace(1)* %arg
230 ret void
231}
232
233; GCN-LABEL: {{^}}s_test_smed3_i32_pat_5:
234; GCN: v_med3_i32 v{{[0-9]+}}, s{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
235define void @s_test_smed3_i32_pat_5(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
236bb:
237 %tmp0 = call i32 @smin(i32 %y, i32 %x)
238 %tmp1 = call i32 @smax(i32 %y, i32 %x)
239 %tmp2 = call i32 @smin(i32 %tmp1, i32 %z)
240 %tmp3 = call i32 @smax(i32 %tmp0, i32 %tmp2)
241 store i32 %tmp3, i32 addrspace(1)* %arg
242 ret void
243}
244
245; GCN-LABEL: {{^}}s_test_smed3_i32_pat_6:
246; GCN: v_med3_i32 v{{[0-9]+}}, s{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
247define void @s_test_smed3_i32_pat_6(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
248bb:
249 %tmp0 = call i32 @smin(i32 %y, i32 %x)
250 %tmp1 = call i32 @smax(i32 %x, i32 %y)
251 %tmp2 = call i32 @smin(i32 %z, i32 %tmp1)
252 %tmp3 = call i32 @smax(i32 %tmp0, i32 %tmp2)
253 store i32 %tmp3, i32 addrspace(1)* %arg
254 ret void
255}
256
257; GCN-LABEL: {{^}}s_test_smed3_i32_pat_7:
258; GCN: v_med3_i32 v{{[0-9]+}}, s{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
259define void @s_test_smed3_i32_pat_7(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
260bb:
261 %tmp0 = call i32 @smin(i32 %y, i32 %x)
262 %tmp1 = call i32 @smax(i32 %y, i32 %x)
263 %tmp2 = call i32 @smin(i32 %z, i32 %tmp1)
264 %tmp3 = call i32 @smax(i32 %tmp0, i32 %tmp2)
265 store i32 %tmp3, i32 addrspace(1)* %arg
266 ret void
267}
268
269; GCN-LABEL: {{^}}s_test_smed3_i32_pat_8:
270; GCN: v_med3_i32 v{{[0-9]+}}, s{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
271define void @s_test_smed3_i32_pat_8(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
272bb:
273 %tmp0 = call i32 @smin(i32 %x, i32 %y)
274 %tmp1 = call i32 @smax(i32 %x, i32 %y)
275 %tmp2 = call i32 @smin(i32 %tmp1, i32 %z)
276 %tmp3 = call i32 @smax(i32 %tmp2, i32 %tmp0)
277 store i32 %tmp3, i32 addrspace(1)* %arg
278 ret void
279}
280
281; GCN-LABEL: {{^}}s_test_smed3_i32_pat_9:
282; GCN: v_med3_i32 v{{[0-9]+}}, s{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
283define void @s_test_smed3_i32_pat_9(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
284bb:
285 %tmp0 = call i32 @smin(i32 %x, i32 %y)
286 %tmp1 = call i32 @smax(i32 %y, i32 %x)
287 %tmp2 = call i32 @smin(i32 %tmp1, i32 %z)
288 %tmp3 = call i32 @smax(i32 %tmp2, i32 %tmp0)
289 store i32 %tmp3, i32 addrspace(1)* %arg
290 ret void
291}
292
293; GCN-LABEL: {{^}}s_test_smed3_i32_pat_10:
294; GCN: v_med3_i32 v{{[0-9]+}}, s{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
295define void @s_test_smed3_i32_pat_10(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
296bb:
297 %tmp0 = call i32 @smin(i32 %x, i32 %y)
298 %tmp1 = call i32 @smax(i32 %x, i32 %y)
299 %tmp2 = call i32 @smin(i32 %z, i32 %tmp1)
300 %tmp3 = call i32 @smax(i32 %tmp2, i32 %tmp0)
301 store i32 %tmp3, i32 addrspace(1)* %arg
302 ret void
303}
304
305; GCN-LABEL: {{^}}s_test_smed3_i32_pat_11:
306; GCN: v_med3_i32 v{{[0-9]+}}, s{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
307define void @s_test_smed3_i32_pat_11(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
308bb:
309 %tmp0 = call i32 @smin(i32 %x, i32 %y)
310 %tmp1 = call i32 @smax(i32 %y, i32 %x)
311 %tmp2 = call i32 @smin(i32 %z, i32 %tmp1)
312 %tmp3 = call i32 @smax(i32 %tmp2, i32 %tmp0)
313 store i32 %tmp3, i32 addrspace(1)* %arg
314 ret void
315}
316
317; GCN-LABEL: {{^}}s_test_smed3_i32_pat_12:
318; GCN: v_med3_i32 v{{[0-9]+}}, s{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
319define void @s_test_smed3_i32_pat_12(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
320bb:
321 %tmp0 = call i32 @smin(i32 %y, i32 %x)
322 %tmp1 = call i32 @smax(i32 %x, i32 %y)
323 %tmp2 = call i32 @smin(i32 %tmp1, i32 %z)
324 %tmp3 = call i32 @smax(i32 %tmp2, i32 %tmp0)
325 store i32 %tmp3, i32 addrspace(1)* %arg
326 ret void
327}
328
329; GCN-LABEL: {{^}}s_test_smed3_i32_pat_13:
330; GCN: v_med3_i32 v{{[0-9]+}}, s{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
331define void @s_test_smed3_i32_pat_13(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
332bb:
333 %tmp0 = call i32 @smin(i32 %y, i32 %x)
334 %tmp1 = call i32 @smax(i32 %y, i32 %x)
335 %tmp2 = call i32 @smin(i32 %tmp1, i32 %z)
336 %tmp3 = call i32 @smax(i32 %tmp2, i32 %tmp0)
337 store i32 %tmp3, i32 addrspace(1)* %arg
338 ret void
339}
340
341; GCN-LABEL: {{^}}s_test_smed3_i32_pat_14:
342; GCN: v_med3_i32 v{{[0-9]+}}, s{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
343define void @s_test_smed3_i32_pat_14(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
344bb:
345 %tmp0 = call i32 @smin(i32 %y, i32 %x)
346 %tmp1 = call i32 @smax(i32 %x, i32 %y)
347 %tmp2 = call i32 @smin(i32 %z, i32 %tmp1)
348 %tmp3 = call i32 @smax(i32 %tmp2, i32 %tmp0)
349 store i32 %tmp3, i32 addrspace(1)* %arg
350 ret void
351}
352
353; GCN-LABEL: {{^}}s_test_smed3_i32_pat_15:
354; GCN: v_med3_i32 v{{[0-9]+}}, s{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
355define void @s_test_smed3_i32_pat_15(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
356bb:
357 %tmp0 = call i32 @smin(i32 %y, i32 %x)
358 %tmp1 = call i32 @smax(i32 %y, i32 %x)
359 %tmp2 = call i32 @smin(i32 %z, i32 %tmp1)
360 %tmp3 = call i32 @smax(i32 %tmp2, i32 %tmp0)
361 store i32 %tmp3, i32 addrspace(1)* %arg
362 ret void
363}
364
365; GCN-LABEL: {{^}}s_test_smed3_i16_pat_0:
366; GCN: s_sext_i32_i16
367; GCN: s_sext_i32_i16
368; GCN: s_sext_i32_i16
369; GCN: v_med3_i32 v{{[0-9]+}}, s{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
370define void @s_test_smed3_i16_pat_0(i16 addrspace(1)* %arg, i16 %x, i16 %y, i16 %z) #1 {
371bb:
372 %tmp0 = call i16 @smin16(i16 %x, i16 %y)
373 %tmp1 = call i16 @smax16(i16 %x, i16 %y)
374 %tmp2 = call i16 @smin16(i16 %tmp1, i16 %z)
375 %tmp3 = call i16 @smax16(i16 %tmp0, i16 %tmp2)
376 store i16 %tmp3, i16 addrspace(1)* %arg
377 ret void
378}
379
380; GCN-LABEL: {{^}}s_test_smed3_i8_pat_0:
381; GCN: s_sext_i32_i8
382; GCN: s_sext_i32_i8
383; GCN: s_sext_i32_i8
384; GCN: v_med3_i32 v{{[0-9]+}}, s{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
385define void @s_test_smed3_i8_pat_0(i8 addrspace(1)* %arg, i8 %x, i8 %y, i8 %z) #1 {
386bb:
387 %tmp0 = call i8 @smin8(i8 %x, i8 %y)
388 %tmp1 = call i8 @smax8(i8 %x, i8 %y)
389 %tmp2 = call i8 @smin8(i8 %tmp1, i8 %z)
390 %tmp3 = call i8 @smax8(i8 %tmp0, i8 %tmp2)
391 store i8 %tmp3, i8 addrspace(1)* %arg
392 ret void
393}
394
395; GCN-LABEL: {{^}}s_test_smed3_i32_pat_0_multi_use_0:
396; GCN-NOT: v_med3_i32
397define void @s_test_smed3_i32_pat_0_multi_use_0(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
398bb:
399 %tmp0 = call i32 @smin(i32 %x, i32 %y)
400 %tmp1 = call i32 @smax(i32 %x, i32 %y)
401 %tmp2 = call i32 @smin(i32 %tmp1, i32 %z)
402 %tmp3 = call i32 @smax(i32 %tmp0, i32 %tmp2)
403 store volatile i32 %tmp0, i32 addrspace(1)* %arg
404 store volatile i32 %tmp3, i32 addrspace(1)* %arg
405 ret void
406}
407
408; GCN-LABEL: {{^}}s_test_smed3_i32_pat_0_multi_use_1:
409; GCN-NOT: v_med3_i32
410define void @s_test_smed3_i32_pat_0_multi_use_1(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
411bb:
412 %tmp0 = call i32 @smin(i32 %x, i32 %y)
413 %tmp1 = call i32 @smax(i32 %x, i32 %y)
414 %tmp2 = call i32 @smin(i32 %tmp1, i32 %z)
415 %tmp3 = call i32 @smax(i32 %tmp0, i32 %tmp2)
416 store volatile i32 %tmp1, i32 addrspace(1)* %arg
417 store volatile i32 %tmp3, i32 addrspace(1)* %arg
418 ret void
419}
420
421; GCN-LABEL: {{^}}s_test_smed3_i32_pat_0_multi_use_2:
422; GCN-NOT: v_med3_i32
423define void @s_test_smed3_i32_pat_0_multi_use_2(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
424bb:
425 %tmp0 = call i32 @smin(i32 %x, i32 %y)
426 %tmp1 = call i32 @smax(i32 %x, i32 %y)
427 %tmp2 = call i32 @smin(i32 %tmp1, i32 %z)
428 %tmp3 = call i32 @smax(i32 %tmp0, i32 %tmp2)
429 store volatile i32 %tmp2, i32 addrspace(1)* %arg
430 store volatile i32 %tmp3, i32 addrspace(1)* %arg
431 ret void
432}
433
434; GCN-LABEL: {{^}}s_test_smed3_i32_pat_0_multi_use_result:
435; GCN: v_med3_i32 v{{[0-9]+}}, s{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
436define void @s_test_smed3_i32_pat_0_multi_use_result(i32 addrspace(1)* %arg, i32 %x, i32 %y, i32 %z) #1 {
437bb:
438 %tmp0 = call i32 @smin(i32 %x, i32 %y)
439 %tmp1 = call i32 @smax(i32 %x, i32 %y)
440 %tmp2 = call i32 @smin(i32 %tmp1, i32 %z)
441 %tmp3 = call i32 @smax(i32 %tmp0, i32 %tmp2)
442 store volatile i32 %tmp3, i32 addrspace(1)* %arg
443 store volatile i32 %tmp3, i32 addrspace(1)* %arg
444 ret void
445}
446
Matt Arsenaultf639c322016-01-28 20:53:42 +0000447attributes #0 = { nounwind readnone }
448attributes #1 = { nounwind }
Matt Arsenaultc89f2912016-03-07 21:54:48 +0000449attributes #2 = { nounwind readnone alwaysinline }