2016-12-21 Vladimir Makarov <vmakarov@redhat.com>
[official-gcc.git] / gcc / testsuite / gcc.target / i386 / avx512bw-knotd-1.c
blob8a7e033826b360fccdf9f4c31363885c58e939cd
1 /* { dg-do compile } */
2 /* { dg-options "-mavx512bw -O2" } */
3 /* { dg-final { scan-assembler-times "knotd\[ \\t\]+\[^\{\n\]*%k\[0-7\](?:\n|\[ \\t\]+#)" 1 } } */
5 #include <immintrin.h>
7 void
8 avx512bw_test ()
10 __mmask32 k1, k2;
11 volatile __m512i x = _mm512_setzero_si512 ();
13 __asm__( "kmovd %1, %0" : "=k" (k1) : "r" (45) );
15 k2 = _knot_mask32 (k1);
16 x = _mm512_mask_add_epi16 (x, k1, x, x);
17 x = _mm512_mask_add_epi16 (x, k2, x, x);