1 /* { dg-do run } */
2 /* { dg-require-effective-target avx512f } */
3 /* { dg-options "-O2 -mavx512f" } */
4 
5 #include "avx512f-check.h"
6 
7 static __m512i
8 __attribute__((noinline))
foo(char * v)9 foo (char *v)
10 {
11   return _mm512_set_epi8 (v[63], v[62], v[61], v[60],
12 			  v[59], v[58], v[57], v[56],
13 			  v[55], v[54], v[53], v[52],
14 			  v[51], v[50], v[49], v[48],
15 			  v[47], v[46], v[45], v[44],
16 			  v[43], v[42], v[41], v[40],
17 			  v[39], v[38], v[37], v[36],
18 			  v[35], v[34], v[33], v[32],
19 			  v[31], v[30], v[29], v[28],
20 			  v[27], v[26], v[25], v[24],
21 			  v[23], v[22], v[21], v[20],
22 			  v[19], v[18], v[17], v[16],
23 			  v[15], v[14], v[13], v[12],
24 			  v[11], v[10], v[9], v[8],
25 			  v[7], v[6], v[5], v[4],
26 			  v[3], v[2], v[1], v[0]);
27 }
28 
29 static void
avx512f_test(void)30 avx512f_test (void)
31 {
32   char v[64] =
33     {
34       -3, 60, 48, 108, -90, 37, -48, 78,
35       4, 33, 81, 4, -89, -112, 8, 68,
36       -13, 30, 78, 149, -70, -37, 98, 38,
37       41, 73, 89, 14, 80, 117, 108, 8,
38       60, 48, 108, -90, 37, -48, 78, 4,
39       33, 81, 4, -89, -112, 8, 68, -13,
40       30, 78, 149, -70, -37, 98, 38, 41,
41       73, 89, 14, 80, 117, 108, -3
42     };
43   union512i_b u;
44 
45   u.x = foo (v);
46   if (check_union512i_b (u, v))
47     abort ();
48 }
49