1 /* { dg-do run } */
2 /* { dg-options "-O2 -mavx512dq" } */
3 /* { dg-require-effective-target avx512dq } */
4 
5 #define AVX512DQ
6 #include "avx512f-helper.h"
7 
8 #define SIZE (AVX512F_LEN / 64)
9 #include "avx512f-mask-type.h"
10 
11 void
CALC(long long * r,MASK_TYPE s)12 CALC (long long *r, MASK_TYPE s)
13 {
14   int i;
15   long long all_ones = 0xffffffffffffffff;
16 
17   for (i = 0; i < SIZE; i++)
18     r[i] = ((s >> i) & 1) ? all_ones : 0;
19 }
20 
21 void
TEST(void)22 TEST (void)
23 {
24   int i;
25   UNION_TYPE (AVX512F_LEN, i_q) res, res_ref;
26   MASK_TYPE src = (MASK_TYPE) 0xff;
27 
28   res.x = INTRINSIC (_movm_epi64) (src);
29 
30   CALC (res_ref.a, src);
31 
32   if (UNION_CHECK (AVX512F_LEN, i_q) (res, res_ref.a))
33     abort ();
34 }
35