cpu_avx512_knl.c 956 B

12345678910111213141516171819202122232425
  1. #if defined(DETECT_FEATURES) && defined(__INTEL_COMPILER)
  2. /*
  3. * Unlike GCC and CLANG, Intel Compiler exposes all supported intrinsics,
  4. * whether or not the build options for those features are specified.
  5. * Therefore, we must test #definitions of CPU features when option native/host
  6. * is enabled via `--cpu-baseline` or through env var `CFLAGS` otherwise
  7. * the test will be broken and leads to enable all possible features.
  8. */
  9. #if !defined(__AVX512ER__) || !defined(__AVX512PF__)
  10. #error "HOST/ARCH doesn't support Knights Landing AVX512 features"
  11. #endif
  12. #endif
  13. #include <immintrin.h>
  14. int main(int argc, char **argv)
  15. {
  16. int base[128];
  17. __m512d ad = _mm512_loadu_pd((const __m512d*)argv[argc-1]);
  18. /* ER */
  19. __m512i a = _mm512_castpd_si512(_mm512_exp2a23_pd(ad));
  20. /* PF */
  21. _mm512_mask_prefetch_i64scatter_pd(base, _mm512_cmpeq_epi64_mask(a, a), a, 1, _MM_HINT_T1);
  22. return base[0];
  23. }