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