1/* { dg-do compile } */
2/* { dg-options "-mavx512f -O2" } */
3/* { dg-final { scan-assembler-times "vpgatherdd\[ \\t\]+\[^\{\n\]*zmm\[0-9\]\[^\n\]*zmm\[0-9\]{%k\[1-7\]}(?:\n|\[ \\t\]+#)" 2 } } */
4
5#include <immintrin.h>
6
7volatile __m512i x, idx;
8volatile __mmask16 m16;
9int *base;
10
11void extern
12avx512f_test (void)
13{
14  x = _mm512_i32gather_epi32 (idx, base, 8);
15  x = _mm512_mask_i32gather_epi32 (x, m16, idx, base, 8);
16}
17