Initial support for AVX-512{VL,BW,DQ}
[official-gcc.git] / gcc / testsuite / gcc.target / i386 / avx512dq-vpmovd2m-2.c
blob9693fb6f2afc3d1bf96393ee43cac9210f365b42
1 /* { dg-do run } */
2 /* { dg-options "-O2 -mavx512dq -DAVX512DQ" } */
3 /* { dg-require-effective-target avx512dq } */
5 #include "avx512f-helper.h"
7 #define SIZE (AVX512F_LEN / 32)
8 #include "avx512f-mask-type.h"
10 CALC (MASK_TYPE *r, int *s1)
12 int i;
13 MASK_TYPE res = 0;
14 MASK_TYPE one = 1;
16 for (i = 0; i < SIZE; i++)
17 if (s1[i] >> 31)
18 res = res | (one << i);
20 *r = res;
23 void
24 TEST (void)
26 int i, sign;
27 UNION_TYPE (AVX512F_LEN, i_d) src;
28 MASK_TYPE res, res_ref = 0;
30 sign = -1;
31 for (i = 0; i < SIZE; i++)
33 src.a[i] = 2 * i * sign;
34 sign = sign * -1;
37 res = INTRINSIC (_movepi32_mask) (src.x);
39 CALC (&res_ref, src.a);
41 if (res_ref != res)
42 abort ();