cpu_avx512_skx.c 1010 B

1234567891011121314151617181920212223242526
  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(__AVX512VL__) || !defined(__AVX512BW__) || !defined(__AVX512DQ__)
  10. #error "HOST/ARCH doesn't support SkyLake AVX512 features"
  11. #endif
  12. #endif
  13. #include <immintrin.h>
  14. int main(int argc, char **argv)
  15. {
  16. __m512i aa = _mm512_abs_epi32(_mm512_loadu_si512((const __m512i*)argv[argc-1]));
  17. /* VL */
  18. __m256i a = _mm256_abs_epi64(_mm512_extracti64x4_epi64(aa, 1));
  19. /* DQ */
  20. __m512i b = _mm512_broadcast_i32x8(a);
  21. /* BW */
  22. b = _mm512_abs_epi16(b);
  23. return _mm_cvtsi128_si32(_mm512_castsi512_si128(b));
  24. }