1  /* { dg-do compile } */
       2  /* { dg-options "-O2 -mavx512vl -mavx512fp16 " } */
       3  /* { dg-final { scan-assembler-times "vgetmantph\[ \\t\]+\[^\{\n\]*%ymm\[0-9\]+(?:\n|\[ \\t\]+#)" 1 } } */
       4  /* { dg-final { scan-assembler-times "vgetmantph\[ \\t\]+\[^\{\n\]*%ymm\[0-9\]+\{%k\[1-7\]\}(?:\n|\[ \\t\]+#)" 1 } } */
       5  /* { dg-final { scan-assembler-times "vgetmantph\[ \\t\]+\[^\{\n\]*%ymm\[0-9\]+\{%k\[1-7\]\}\{z\}(?:\n|\[ \\t\]+#)" 1 } } */
       6  /* { dg-final { scan-assembler-times "vgetmantph\[ \\t\]+\[^\{\n\]*%xmm\[0-9\]+(?:\n|\[ \\t\]+#)" 1 } } */
       7  /* { dg-final { scan-assembler-times "vgetmantph\[ \\t\]+\[^\{\n\]*%xmm\[0-9\]+\{%k\[1-7\]\}(?:\n|\[ \\t\]+#)" 1 } } */
       8  /* { dg-final { scan-assembler-times "vgetmantph\[ \\t\]+\[^\{\n\]*%xmm\[0-9\]+\{%k\[1-7\]\}\{z\}(?:\n|\[ \\t\]+#)" 1 } } */
       9  
      10  #include <immintrin.h>
      11  
      12  volatile __m256h x, y;
      13  volatile __m128h a, b;
      14  volatile __mmask8 m8;
      15  volatile __mmask16 m16;
      16  
      17  void extern
      18  avx512vl_test (void)
      19  {
      20    x = _mm256_getmant_ph (y, _MM_MANT_NORM_p75_1p5, _MM_MANT_SIGN_src);
      21    x = _mm256_mask_getmant_ph (x, m16, y, _MM_MANT_NORM_p75_1p5,
      22  			      _MM_MANT_SIGN_src);
      23    x = _mm256_maskz_getmant_ph (m16, y, _MM_MANT_NORM_p75_1p5,
      24  			       _MM_MANT_SIGN_src);
      25    a = _mm_getmant_ph (b, _MM_MANT_NORM_p75_1p5, _MM_MANT_SIGN_src);
      26    a = _mm_mask_getmant_ph (a, m8, b, _MM_MANT_NORM_p75_1p5,
      27  			   _MM_MANT_SIGN_src);
      28    a = _mm_maskz_getmant_ph (m8, b, _MM_MANT_NORM_p75_1p5,
      29  			    _MM_MANT_SIGN_src);
      30  }