1; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2; RUN: llc < %s -mtriple=x86_64-apple-darwin -march=x86 -mattr=avx2 | FileCheck %s
3
4define <16 x i16> @test_x86_avx2_pblendw(<16 x i16> %a0, <16 x i16> %a1) {
5; CHECK-LABEL: test_x86_avx2_pblendw:
6; CHECK:       ## BB#0:
7; CHECK-NEXT:    vpblendw {{.*#+}} ymm0 = ymm1[0,1,2],ymm0[3,4,5,6,7],ymm1[8,9,10],ymm0[11,12,13,14,15]
8; CHECK-NEXT:    retl
9  %res = call <16 x i16> @llvm.x86.avx2.pblendw(<16 x i16> %a0, <16 x i16> %a1, i32 7) ; <<16 x i16>> [#uses=1]
10  ret <16 x i16> %res
11}
12declare <16 x i16> @llvm.x86.avx2.pblendw(<16 x i16>, <16 x i16>, i32) nounwind readnone
13
14
15define <4 x i32> @test_x86_avx2_pblendd_128(<4 x i32> %a0, <4 x i32> %a1) {
16; CHECK-LABEL: test_x86_avx2_pblendd_128:
17; CHECK:       ## BB#0:
18; CHECK-NEXT:    vpblendd {{.*#+}} xmm0 = xmm1[0,1,2],xmm0[3]
19; CHECK-NEXT:    retl
20  %res = call <4 x i32> @llvm.x86.avx2.pblendd.128(<4 x i32> %a0, <4 x i32> %a1, i32 7) ; <<4 x i32>> [#uses=1]
21  ret <4 x i32> %res
22}
23declare <4 x i32> @llvm.x86.avx2.pblendd.128(<4 x i32>, <4 x i32>, i32) nounwind readnone
24
25
26define <8 x i32> @test_x86_avx2_pblendd_256(<8 x i32> %a0, <8 x i32> %a1) {
27; CHECK-LABEL: test_x86_avx2_pblendd_256:
28; CHECK:       ## BB#0:
29; CHECK-NEXT:    vpblendd {{.*#+}} ymm0 = ymm1[0,1,2],ymm0[3,4,5,6,7]
30; CHECK-NEXT:    retl
31  %res = call <8 x i32> @llvm.x86.avx2.pblendd.256(<8 x i32> %a0, <8 x i32> %a1, i32 7) ; <<8 x i32>> [#uses=1]
32  ret <8 x i32> %res
33}
34declare <8 x i32> @llvm.x86.avx2.pblendd.256(<8 x i32>, <8 x i32>, i32) nounwind readnone
35
36
37define <16 x i16> @test_x86_avx2_mpsadbw(<32 x i8> %a0, <32 x i8> %a1) {
38; CHECK-LABEL: test_x86_avx2_mpsadbw:
39; CHECK:       ## BB#0:
40; CHECK-NEXT:    vmpsadbw $7, %ymm1, %ymm0, %ymm0
41; CHECK-NEXT:    retl
42  %res = call <16 x i16> @llvm.x86.avx2.mpsadbw(<32 x i8> %a0, <32 x i8> %a1, i32 7) ; <<16 x i16>> [#uses=1]
43  ret <16 x i16> %res
44}
45declare <16 x i16> @llvm.x86.avx2.mpsadbw(<32 x i8>, <32 x i8>, i32) nounwind readnone
46
47
48define <4 x i64> @test_x86_avx2_psll_dq_bs(<4 x i64> %a0) {
49; CHECK-LABEL: test_x86_avx2_psll_dq_bs:
50; CHECK:       ## BB#0:
51; CHECK-NEXT:    vpslldq {{.*#+}} ymm0 = zero,zero,zero,zero,zero,zero,zero,ymm0[0,1,2,3,4,5,6,7,8],zero,zero,zero,zero,zero,zero,zero,ymm0[16,17,18,19,20,21,22,23,24]
52; CHECK-NEXT:    retl
53  %res = call <4 x i64> @llvm.x86.avx2.psll.dq.bs(<4 x i64> %a0, i32 7) ; <<4 x i64>> [#uses=1]
54  ret <4 x i64> %res
55}
56declare <4 x i64> @llvm.x86.avx2.psll.dq.bs(<4 x i64>, i32) nounwind readnone
57
58
59define <4 x i64> @test_x86_avx2_psrl_dq_bs(<4 x i64> %a0) {
60; CHECK-LABEL: test_x86_avx2_psrl_dq_bs:
61; CHECK:       ## BB#0:
62; CHECK-NEXT:    vpsrldq {{.*#+}} ymm0 = ymm0[7,8,9,10,11,12,13,14,15],zero,zero,zero,zero,zero,zero,zero,ymm0[23,24,25,26,27,28,29,30,31],zero,zero,zero,zero,zero,zero,zero
63; CHECK-NEXT:    retl
64  %res = call <4 x i64> @llvm.x86.avx2.psrl.dq.bs(<4 x i64> %a0, i32 7) ; <<4 x i64>> [#uses=1]
65  ret <4 x i64> %res
66}
67declare <4 x i64> @llvm.x86.avx2.psrl.dq.bs(<4 x i64>, i32) nounwind readnone
68
69
70define <4 x i64> @test_x86_avx2_psll_dq(<4 x i64> %a0) {
71; CHECK-LABEL: test_x86_avx2_psll_dq:
72; CHECK:       ## BB#0:
73; CHECK-NEXT:    vpslldq {{.*#+}} ymm0 = zero,ymm0[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14],zero,ymm0[16,17,18,19,20,21,22,23,24,25,26,27,28,29,30]
74; CHECK-NEXT:    retl
75  %res = call <4 x i64> @llvm.x86.avx2.psll.dq(<4 x i64> %a0, i32 8) ; <<4 x i64>> [#uses=1]
76  ret <4 x i64> %res
77}
78declare <4 x i64> @llvm.x86.avx2.psll.dq(<4 x i64>, i32) nounwind readnone
79
80
81define <4 x i64> @test_x86_avx2_psrl_dq(<4 x i64> %a0) {
82; CHECK-LABEL: test_x86_avx2_psrl_dq:
83; CHECK:       ## BB#0:
84; CHECK-NEXT:    vpsrldq {{.*#+}} ymm0 = ymm0[1,2,3,4,5,6,7,8,9,10,11,12,13,14,15],zero,ymm0[17,18,19,20,21,22,23,24,25,26,27,28,29,30,31],zero
85; CHECK-NEXT:    retl
86  %res = call <4 x i64> @llvm.x86.avx2.psrl.dq(<4 x i64> %a0, i32 8) ; <<4 x i64>> [#uses=1]
87  ret <4 x i64> %res
88}
89declare <4 x i64> @llvm.x86.avx2.psrl.dq(<4 x i64>, i32) nounwind readnone
90
91
92define <2 x i64> @test_x86_avx2_vextracti128(<4 x i64> %a0) {
93; CHECK-LABEL: test_x86_avx2_vextracti128:
94; CHECK:       ## BB#0:
95; CHECK-NEXT:    vextractf128 $1, %ymm0, %xmm0
96; CHECK-NEXT:    vzeroupper
97; CHECK-NEXT:    retl
98  %res = call <2 x i64> @llvm.x86.avx2.vextracti128(<4 x i64> %a0, i8 7)
99  ret <2 x i64> %res
100}
101declare <2 x i64> @llvm.x86.avx2.vextracti128(<4 x i64>, i8) nounwind readnone
102
103
104define <4 x i64> @test_x86_avx2_vinserti128(<4 x i64> %a0, <2 x i64> %a1) {
105; CHECK-LABEL: test_x86_avx2_vinserti128:
106; CHECK:       ## BB#0:
107; CHECK-NEXT:    vinsertf128 $1, %xmm1, %ymm0, %ymm0
108; CHECK-NEXT:    retl
109  %res = call <4 x i64> @llvm.x86.avx2.vinserti128(<4 x i64> %a0, <2 x i64> %a1, i8 7)
110  ret <4 x i64> %res
111}
112declare <4 x i64> @llvm.x86.avx2.vinserti128(<4 x i64>, <2 x i64>, i8) nounwind readnone
113
114
115define <4 x double> @test_x86_avx2_vbroadcast_sd_pd_256(<2 x double> %a0) {
116; CHECK-LABEL: test_x86_avx2_vbroadcast_sd_pd_256:
117; CHECK:       ## BB#0:
118; CHECK-NEXT:    vbroadcastsd %xmm0, %ymm0
119; CHECK-NEXT:    retl
120  %res = call <4 x double> @llvm.x86.avx2.vbroadcast.sd.pd.256(<2 x double> %a0)
121  ret <4 x double> %res
122}
123declare <4 x double> @llvm.x86.avx2.vbroadcast.sd.pd.256(<2 x double>) nounwind readonly
124
125
126define <4 x float> @test_x86_avx2_vbroadcast_ss_ps(<4 x float> %a0) {
127; CHECK-LABEL: test_x86_avx2_vbroadcast_ss_ps:
128; CHECK:       ## BB#0:
129; CHECK-NEXT:    vbroadcastss %xmm0, %xmm0
130; CHECK-NEXT:    retl
131  %res = call <4 x float> @llvm.x86.avx2.vbroadcast.ss.ps(<4 x float> %a0)
132  ret <4 x float> %res
133}
134declare <4 x float> @llvm.x86.avx2.vbroadcast.ss.ps(<4 x float>) nounwind readonly
135
136
137define <8 x float> @test_x86_avx2_vbroadcast_ss_ps_256(<4 x float> %a0) {
138; CHECK-LABEL: test_x86_avx2_vbroadcast_ss_ps_256:
139; CHECK:       ## BB#0:
140; CHECK-NEXT:    vbroadcastss %xmm0, %ymm0
141; CHECK-NEXT:    retl
142  %res = call <8 x float> @llvm.x86.avx2.vbroadcast.ss.ps.256(<4 x float> %a0)
143  ret <8 x float> %res
144}
145declare <8 x float> @llvm.x86.avx2.vbroadcast.ss.ps.256(<4 x float>) nounwind readonly
146
147
148define <16 x i8> @test_x86_avx2_pbroadcastb_128(<16 x i8> %a0) {
149; CHECK-LABEL: test_x86_avx2_pbroadcastb_128:
150; CHECK:       ## BB#0:
151; CHECK-NEXT:    vpbroadcastb %xmm0, %xmm0
152; CHECK-NEXT:    retl
153  %res = call <16 x i8> @llvm.x86.avx2.pbroadcastb.128(<16 x i8> %a0)
154  ret <16 x i8> %res
155}
156declare <16 x i8> @llvm.x86.avx2.pbroadcastb.128(<16 x i8>) nounwind readonly
157
158
159define <32 x i8> @test_x86_avx2_pbroadcastb_256(<16 x i8> %a0) {
160; CHECK-LABEL: test_x86_avx2_pbroadcastb_256:
161; CHECK:       ## BB#0:
162; CHECK-NEXT:    vpbroadcastb %xmm0, %ymm0
163; CHECK-NEXT:    retl
164  %res = call <32 x i8> @llvm.x86.avx2.pbroadcastb.256(<16 x i8> %a0)
165  ret <32 x i8> %res
166}
167declare <32 x i8> @llvm.x86.avx2.pbroadcastb.256(<16 x i8>) nounwind readonly
168
169
170define <8 x i16> @test_x86_avx2_pbroadcastw_128(<8 x i16> %a0) {
171; CHECK-LABEL: test_x86_avx2_pbroadcastw_128:
172; CHECK:       ## BB#0:
173; CHECK-NEXT:    vpbroadcastw %xmm0, %xmm0
174; CHECK-NEXT:    retl
175  %res = call <8 x i16> @llvm.x86.avx2.pbroadcastw.128(<8 x i16> %a0)
176  ret <8 x i16> %res
177}
178declare <8 x i16> @llvm.x86.avx2.pbroadcastw.128(<8 x i16>) nounwind readonly
179
180
181define <16 x i16> @test_x86_avx2_pbroadcastw_256(<8 x i16> %a0) {
182; CHECK-LABEL: test_x86_avx2_pbroadcastw_256:
183; CHECK:       ## BB#0:
184; CHECK-NEXT:    vpbroadcastw %xmm0, %ymm0
185; CHECK-NEXT:    retl
186  %res = call <16 x i16> @llvm.x86.avx2.pbroadcastw.256(<8 x i16> %a0)
187  ret <16 x i16> %res
188}
189declare <16 x i16> @llvm.x86.avx2.pbroadcastw.256(<8 x i16>) nounwind readonly
190
191
192define <4 x i32> @test_x86_avx2_pbroadcastd_128(<4 x i32> %a0) {
193; CHECK-LABEL: test_x86_avx2_pbroadcastd_128:
194; CHECK:       ## BB#0:
195; CHECK-NEXT:    vbroadcastss %xmm0, %xmm0
196; CHECK-NEXT:    retl
197  %res = call <4 x i32> @llvm.x86.avx2.pbroadcastd.128(<4 x i32> %a0)
198  ret <4 x i32> %res
199}
200declare <4 x i32> @llvm.x86.avx2.pbroadcastd.128(<4 x i32>) nounwind readonly
201
202
203define <8 x i32> @test_x86_avx2_pbroadcastd_256(<4 x i32> %a0) {
204; CHECK-LABEL: test_x86_avx2_pbroadcastd_256:
205; CHECK:       ## BB#0:
206; CHECK-NEXT:    vbroadcastss %xmm0, %ymm0
207; CHECK-NEXT:    retl
208  %res = call <8 x i32> @llvm.x86.avx2.pbroadcastd.256(<4 x i32> %a0)
209  ret <8 x i32> %res
210}
211declare <8 x i32> @llvm.x86.avx2.pbroadcastd.256(<4 x i32>) nounwind readonly
212
213
214define <2 x i64> @test_x86_avx2_pbroadcastq_128(<2 x i64> %a0) {
215; CHECK-LABEL: test_x86_avx2_pbroadcastq_128:
216; CHECK:       ## BB#0:
217; CHECK-NEXT:    vpbroadcastq %xmm0, %xmm0
218; CHECK-NEXT:    retl
219  %res = call <2 x i64> @llvm.x86.avx2.pbroadcastq.128(<2 x i64> %a0)
220  ret <2 x i64> %res
221}
222declare <2 x i64> @llvm.x86.avx2.pbroadcastq.128(<2 x i64>) nounwind readonly
223
224
225define <4 x i64> @test_x86_avx2_pbroadcastq_256(<2 x i64> %a0) {
226; CHECK-LABEL: test_x86_avx2_pbroadcastq_256:
227; CHECK:       ## BB#0:
228; CHECK-NEXT:    vbroadcastsd %xmm0, %ymm0
229; CHECK-NEXT:    retl
230  %res = call <4 x i64> @llvm.x86.avx2.pbroadcastq.256(<2 x i64> %a0)
231  ret <4 x i64> %res
232}
233declare <4 x i64> @llvm.x86.avx2.pbroadcastq.256(<2 x i64>) nounwind readonly
234
235
236define <8 x i32> @test_x86_avx2_pmovsxbd(<16 x i8> %a0) {
237; CHECK-LABEL: test_x86_avx2_pmovsxbd:
238; CHECK:       ## BB#0:
239; CHECK-NEXT:    vpmovsxbd %xmm0, %ymm0
240; CHECK-NEXT:    retl
241  %res = call <8 x i32> @llvm.x86.avx2.pmovsxbd(<16 x i8> %a0) ; <<8 x i32>> [#uses=1]
242  ret <8 x i32> %res
243}
244declare <8 x i32> @llvm.x86.avx2.pmovsxbd(<16 x i8>) nounwind readnone
245
246
247define <4 x i64> @test_x86_avx2_pmovsxbq(<16 x i8> %a0) {
248; CHECK-LABEL: test_x86_avx2_pmovsxbq:
249; CHECK:       ## BB#0:
250; CHECK-NEXT:    vpmovsxbq %xmm0, %ymm0
251; CHECK-NEXT:    retl
252  %res = call <4 x i64> @llvm.x86.avx2.pmovsxbq(<16 x i8> %a0) ; <<4 x i64>> [#uses=1]
253  ret <4 x i64> %res
254}
255declare <4 x i64> @llvm.x86.avx2.pmovsxbq(<16 x i8>) nounwind readnone
256
257
258define <16 x i16> @test_x86_avx2_pmovsxbw(<16 x i8> %a0) {
259; CHECK-LABEL: test_x86_avx2_pmovsxbw:
260; CHECK:       ## BB#0:
261; CHECK-NEXT:    vpmovsxbw %xmm0, %ymm0
262; CHECK-NEXT:    retl
263  %res = call <16 x i16> @llvm.x86.avx2.pmovsxbw(<16 x i8> %a0) ; <<8 x i16>> [#uses=1]
264  ret <16 x i16> %res
265}
266declare <16 x i16> @llvm.x86.avx2.pmovsxbw(<16 x i8>) nounwind readnone
267
268
269define <4 x i64> @test_x86_avx2_pmovsxdq(<4 x i32> %a0) {
270; CHECK-LABEL: test_x86_avx2_pmovsxdq:
271; CHECK:       ## BB#0:
272; CHECK-NEXT:    vpmovsxdq %xmm0, %ymm0
273; CHECK-NEXT:    retl
274  %res = call <4 x i64> @llvm.x86.avx2.pmovsxdq(<4 x i32> %a0) ; <<4 x i64>> [#uses=1]
275  ret <4 x i64> %res
276}
277declare <4 x i64> @llvm.x86.avx2.pmovsxdq(<4 x i32>) nounwind readnone
278
279
280define <8 x i32> @test_x86_avx2_pmovsxwd(<8 x i16> %a0) {
281; CHECK-LABEL: test_x86_avx2_pmovsxwd:
282; CHECK:       ## BB#0:
283; CHECK-NEXT:    vpmovsxwd %xmm0, %ymm0
284; CHECK-NEXT:    retl
285  %res = call <8 x i32> @llvm.x86.avx2.pmovsxwd(<8 x i16> %a0) ; <<8 x i32>> [#uses=1]
286  ret <8 x i32> %res
287}
288declare <8 x i32> @llvm.x86.avx2.pmovsxwd(<8 x i16>) nounwind readnone
289
290
291define <4 x i64> @test_x86_avx2_pmovsxwq(<8 x i16> %a0) {
292; CHECK-LABEL: test_x86_avx2_pmovsxwq:
293; CHECK:       ## BB#0:
294; CHECK-NEXT:    vpmovsxwq %xmm0, %ymm0
295; CHECK-NEXT:    retl
296  %res = call <4 x i64> @llvm.x86.avx2.pmovsxwq(<8 x i16> %a0) ; <<4 x i64>> [#uses=1]
297  ret <4 x i64> %res
298}
299declare <4 x i64> @llvm.x86.avx2.pmovsxwq(<8 x i16>) nounwind readnone
300
301
302define <8 x i32> @test_x86_avx2_pmovzxbd(<16 x i8> %a0) {
303; CHECK-LABEL: test_x86_avx2_pmovzxbd:
304; CHECK:       ## BB#0:
305; CHECK-NEXT:    vpmovzxbd {{.*#+}} ymm0 = xmm0[0],zero,zero,zero,xmm0[1],zero,zero,zero,xmm0[2],zero,zero,zero,xmm0[3],zero,zero,zero,xmm0[4],zero,zero,zero,xmm0[5],zero,zero,zero,xmm0[6],zero,zero,zero,xmm0[7],zero,zero,zero
306; CHECK-NEXT:    retl
307  %res = call <8 x i32> @llvm.x86.avx2.pmovzxbd(<16 x i8> %a0) ; <<8 x i32>> [#uses=1]
308  ret <8 x i32> %res
309}
310declare <8 x i32> @llvm.x86.avx2.pmovzxbd(<16 x i8>) nounwind readnone
311
312
313define <4 x i64> @test_x86_avx2_pmovzxbq(<16 x i8> %a0) {
314; CHECK-LABEL: test_x86_avx2_pmovzxbq:
315; CHECK:       ## BB#0:
316; CHECK-NEXT:    vpmovzxbq {{.*#+}} ymm0 = xmm0[0],zero,zero,zero,zero,zero,zero,zero,xmm0[1],zero,zero,zero,zero,zero,zero,zero,xmm0[2],zero,zero,zero,zero,zero,zero,zero,xmm0[3],zero,zero,zero,zero,zero,zero,zero
317; CHECK-NEXT:    retl
318  %res = call <4 x i64> @llvm.x86.avx2.pmovzxbq(<16 x i8> %a0) ; <<4 x i64>> [#uses=1]
319  ret <4 x i64> %res
320}
321declare <4 x i64> @llvm.x86.avx2.pmovzxbq(<16 x i8>) nounwind readnone
322
323
324define <16 x i16> @test_x86_avx2_pmovzxbw(<16 x i8> %a0) {
325; CHECK-LABEL: test_x86_avx2_pmovzxbw:
326; CHECK:       ## BB#0:
327; CHECK-NEXT:    vpmovzxbw {{.*#+}} ymm0 = xmm0[0],zero,xmm0[1],zero,xmm0[2],zero,xmm0[3],zero,xmm0[4],zero,xmm0[5],zero,xmm0[6],zero,xmm0[7],zero,xmm0[8],zero,xmm0[9],zero,xmm0[10],zero,xmm0[11],zero,xmm0[12],zero,xmm0[13],zero,xmm0[14],zero,xmm0[15],zero
328; CHECK-NEXT:    retl
329  %res = call <16 x i16> @llvm.x86.avx2.pmovzxbw(<16 x i8> %a0) ; <<16 x i16>> [#uses=1]
330  ret <16 x i16> %res
331}
332declare <16 x i16> @llvm.x86.avx2.pmovzxbw(<16 x i8>) nounwind readnone
333
334
335define <4 x i64> @test_x86_avx2_pmovzxdq(<4 x i32> %a0) {
336; CHECK-LABEL: test_x86_avx2_pmovzxdq:
337; CHECK:       ## BB#0:
338; CHECK-NEXT:    vpmovzxdq {{.*#+}} ymm0 = xmm0[0],zero,xmm0[1],zero,xmm0[2],zero,xmm0[3],zero
339; CHECK-NEXT:    retl
340  %res = call <4 x i64> @llvm.x86.avx2.pmovzxdq(<4 x i32> %a0) ; <<4 x i64>> [#uses=1]
341  ret <4 x i64> %res
342}
343declare <4 x i64> @llvm.x86.avx2.pmovzxdq(<4 x i32>) nounwind readnone
344
345
346define <8 x i32> @test_x86_avx2_pmovzxwd(<8 x i16> %a0) {
347; CHECK-LABEL: test_x86_avx2_pmovzxwd:
348; CHECK:       ## BB#0:
349; CHECK-NEXT:    vpmovzxwd {{.*#+}} ymm0 = xmm0[0],zero,xmm0[1],zero,xmm0[2],zero,xmm0[3],zero,xmm0[4],zero,xmm0[5],zero,xmm0[6],zero,xmm0[7],zero
350; CHECK-NEXT:    retl
351  %res = call <8 x i32> @llvm.x86.avx2.pmovzxwd(<8 x i16> %a0) ; <<8 x i32>> [#uses=1]
352  ret <8 x i32> %res
353}
354declare <8 x i32> @llvm.x86.avx2.pmovzxwd(<8 x i16>) nounwind readnone
355
356
357define <4 x i64> @test_x86_avx2_pmovzxwq(<8 x i16> %a0) {
358; CHECK-LABEL: test_x86_avx2_pmovzxwq:
359; CHECK:       ## BB#0:
360; CHECK-NEXT:    vpmovzxwq {{.*#+}} ymm0 = xmm0[0],zero,zero,zero,xmm0[1],zero,zero,zero,xmm0[2],zero,zero,zero,xmm0[3],zero,zero,zero
361; CHECK-NEXT:    retl
362  %res = call <4 x i64> @llvm.x86.avx2.pmovzxwq(<8 x i16> %a0) ; <<4 x i64>> [#uses=1]
363  ret <4 x i64> %res
364}
365declare <4 x i64> @llvm.x86.avx2.pmovzxwq(<8 x i16>) nounwind readnone
366
367; This is checked here because the execution dependency fix pass makes it hard to test in AVX mode since we don't have 256-bit integer instructions
368define void @test_x86_avx_storeu_dq_256(i8* %a0, <32 x i8> %a1) {
369  ; add operation forces the execution domain.
370; CHECK-LABEL: test_x86_avx_storeu_dq_256:
371; CHECK:       ## BB#0:
372; CHECK-NEXT:    movl {{[0-9]+}}(%esp), %eax
373; CHECK-NEXT:    vpaddb LCPI33_0, %ymm0, %ymm0
374; CHECK-NEXT:    vmovdqu %ymm0, (%eax)
375; CHECK-NEXT:    vzeroupper
376; CHECK-NEXT:    retl
377  %a2 = add <32 x i8> %a1, <i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1>
378  call void @llvm.x86.avx.storeu.dq.256(i8* %a0, <32 x i8> %a2)
379  ret void
380}
381declare void @llvm.x86.avx.storeu.dq.256(i8*, <32 x i8>) nounwind
382
383define <32 x i8> @mm256_max_epi8(<32 x i8> %a0, <32 x i8> %a1) {
384; CHECK-LABEL: mm256_max_epi8:
385; CHECK:       ## BB#0:
386; CHECK-NEXT:    vpmaxsb %ymm1, %ymm0, %ymm0
387; CHECK-NEXT:    retl
388;
389  %res = call <32 x i8> @llvm.x86.avx2.pmaxs.b(<32 x i8> %a0, <32 x i8> %a1)
390  ret <32 x i8> %res
391}
392declare <32 x i8> @llvm.x86.avx2.pmaxs.b(<32 x i8>, <32 x i8>) nounwind readnone
393
394define <16 x i16> @mm256_max_epi16(<16 x i16> %a0, <16 x i16> %a1) {
395; CHECK-LABEL: mm256_max_epi16:
396; CHECK:       ## BB#0:
397; CHECK-NEXT:    vpmaxsw %ymm1, %ymm0, %ymm0
398; CHECK-NEXT:    retl
399;
400  %res = call <16 x i16> @llvm.x86.avx2.pmaxs.w(<16 x i16> %a0, <16 x i16> %a1)
401  ret <16 x i16> %res
402}
403declare <16 x i16> @llvm.x86.avx2.pmaxs.w(<16 x i16>, <16 x i16>) nounwind readnone
404
405define <8 x i32> @mm256_max_epi32(<8 x i32> %a0, <8 x i32> %a1) {
406; CHECK-LABEL: mm256_max_epi32:
407; CHECK:       ## BB#0:
408; CHECK-NEXT:    vpmaxsd %ymm1, %ymm0, %ymm0
409; CHECK-NEXT:    retl
410;
411  %res = call <8 x i32> @llvm.x86.avx2.pmaxs.d(<8 x i32> %a0, <8 x i32> %a1)
412  ret <8 x i32> %res
413}
414declare <8 x i32> @llvm.x86.avx2.pmaxs.d(<8 x i32>, <8 x i32>) nounwind readnone
415
416define <32 x i8> @mm256_max_epu8(<32 x i8> %a0, <32 x i8> %a1) {
417; CHECK-LABEL: mm256_max_epu8:
418; CHECK:       ## BB#0:
419; CHECK-NEXT:    vpmaxub %ymm1, %ymm0, %ymm0
420; CHECK-NEXT:    retl
421;
422  %res = call <32 x i8> @llvm.x86.avx2.pmaxu.b(<32 x i8> %a0, <32 x i8> %a1)
423  ret <32 x i8> %res
424}
425declare <32 x i8> @llvm.x86.avx2.pmaxu.b(<32 x i8>, <32 x i8>) nounwind readnone
426
427define <16 x i16> @mm256_max_epu16(<16 x i16> %a0, <16 x i16> %a1) {
428; CHECK-LABEL: mm256_max_epu16:
429; CHECK:       ## BB#0:
430; CHECK-NEXT:    vpmaxuw %ymm1, %ymm0, %ymm0
431; CHECK-NEXT:    retl
432;
433  %res = call <16 x i16> @llvm.x86.avx2.pmaxu.w(<16 x i16> %a0, <16 x i16> %a1)
434  ret <16 x i16> %res
435}
436declare <16 x i16> @llvm.x86.avx2.pmaxu.w(<16 x i16>, <16 x i16>) nounwind readnone
437
438define <8 x i32> @mm256_max_epu32(<8 x i32> %a0, <8 x i32> %a1) {
439; CHECK-LABEL: mm256_max_epu32:
440; CHECK:       ## BB#0:
441; CHECK-NEXT:    vpmaxud %ymm1, %ymm0, %ymm0
442; CHECK-NEXT:    retl
443;
444  %res = call <8 x i32> @llvm.x86.avx2.pmaxu.d(<8 x i32> %a0, <8 x i32> %a1)
445  ret <8 x i32> %res
446}
447declare <8 x i32> @llvm.x86.avx2.pmaxu.d(<8 x i32>, <8 x i32>) nounwind readnone
448
449define <32 x i8> @mm256_min_epi8(<32 x i8> %a0, <32 x i8> %a1) {
450; CHECK-LABEL: mm256_min_epi8:
451; CHECK:       ## BB#0:
452; CHECK-NEXT:    vpminsb %ymm1, %ymm0, %ymm0
453; CHECK-NEXT:    retl
454;
455  %res = call <32 x i8> @llvm.x86.avx2.pmins.b(<32 x i8> %a0, <32 x i8> %a1)
456  ret <32 x i8> %res
457}
458declare <32 x i8> @llvm.x86.avx2.pmins.b(<32 x i8>, <32 x i8>) nounwind readnone
459
460define <16 x i16> @mm256_min_epi16(<16 x i16> %a0, <16 x i16> %a1) {
461; CHECK-LABEL: mm256_min_epi16:
462; CHECK:       ## BB#0:
463; CHECK-NEXT:    vpminsw %ymm1, %ymm0, %ymm0
464; CHECK-NEXT:    retl
465;
466  %res = call <16 x i16> @llvm.x86.avx2.pmins.w(<16 x i16> %a0, <16 x i16> %a1)
467  ret <16 x i16> %res
468}
469declare <16 x i16> @llvm.x86.avx2.pmins.w(<16 x i16>, <16 x i16>) nounwind readnone
470
471define <8 x i32> @mm256_min_epi32(<8 x i32> %a0, <8 x i32> %a1) {
472; CHECK-LABEL: mm256_min_epi32:
473; CHECK:       ## BB#0:
474; CHECK-NEXT:    vpminsd %ymm1, %ymm0, %ymm0
475; CHECK-NEXT:    retl
476;
477  %res = call <8 x i32> @llvm.x86.avx2.pmins.d(<8 x i32> %a0, <8 x i32> %a1)
478  ret <8 x i32> %res
479}
480declare <8 x i32> @llvm.x86.avx2.pmins.d(<8 x i32>, <8 x i32>) nounwind readnone
481
482define <32 x i8> @mm256_min_epu8(<32 x i8> %a0, <32 x i8> %a1) {
483; CHECK-LABEL: mm256_min_epu8:
484; CHECK:       ## BB#0:
485; CHECK-NEXT:    vpminub %ymm1, %ymm0, %ymm0
486; CHECK-NEXT:    retl
487;
488  %res = call <32 x i8> @llvm.x86.avx2.pminu.b(<32 x i8> %a0, <32 x i8> %a1)
489  ret <32 x i8> %res
490}
491declare <32 x i8> @llvm.x86.avx2.pminu.b(<32 x i8>, <32 x i8>) nounwind readnone
492
493define <16 x i16> @mm256_min_epu16(<16 x i16> %a0, <16 x i16> %a1) {
494; CHECK-LABEL: mm256_min_epu16:
495; CHECK:       ## BB#0:
496; CHECK-NEXT:    vpminuw %ymm1, %ymm0, %ymm0
497; CHECK-NEXT:    retl
498;
499  %res = call <16 x i16> @llvm.x86.avx2.pminu.w(<16 x i16> %a0, <16 x i16> %a1)
500  ret <16 x i16> %res
501}
502declare <16 x i16> @llvm.x86.avx2.pminu.w(<16 x i16>, <16 x i16>) nounwind readnone
503
504define <8 x i32> @mm256_min_epu32(<8 x i32> %a0, <8 x i32> %a1) {
505; CHECK-LABEL: mm256_min_epu32:
506; CHECK:       ## BB#0:
507; CHECK-NEXT:    vpminud %ymm1, %ymm0, %ymm0
508; CHECK-NEXT:    retl
509;
510  %res = call <8 x i32> @llvm.x86.avx2.pminu.d(<8 x i32> %a0, <8 x i32> %a1)
511  ret <8 x i32> %res
512}
513declare <8 x i32> @llvm.x86.avx2.pminu.d(<8 x i32>, <8 x i32>) nounwind readnone
514
515