From 914aba846a266eb20fe1a74402dd65f2af697be9 Mon Sep 17 00:00:00 2001 From: Kenneth Heafield Date: Wed, 8 Dec 2021 22:04:53 +0000 Subject: clang-cl compilation --- compile_test/avx2.cc | 10 +++++++++- compile_test/avx512bw.cc | 13 ++++++++++++- compile_test/avx512vnni.cc | 14 +++++++++++++- intgemm/intgemm.cc | 2 +- intgemm/types.h | 19 ++++++++++++++++--- 5 files changed, 51 insertions(+), 7 deletions(-) diff --git a/compile_test/avx2.cc b/compile_test/avx2.cc index 8460fc0..9ed534e 100644 --- a/compile_test/avx2.cc +++ b/compile_test/avx2.cc @@ -1,7 +1,15 @@ // Some compilers don't have AVX2 support. Test for them. #include -#if defined(_MSC_VER) +// clang-cl bug doesn't include these headers when pretending to be MSVC +// https://github.com/llvm/llvm-project/blob/e9a294449575a1e1a0daca470f64914695dc9adc/clang/lib/Headers/immintrin.h#L69-L72 +#if defined(_MSC_VER) && defined(__clang__) +#include +#include +#include +#endif + +#if defined(_MSC_VER) && !defined(__clang__) #define INTGEMM_AVX2 #else #define INTGEMM_AVX2 __attribute__ ((target ("avx2"))) diff --git a/compile_test/avx512bw.cc b/compile_test/avx512bw.cc index 2cd4c6a..2361f75 100644 --- a/compile_test/avx512bw.cc +++ b/compile_test/avx512bw.cc @@ -1,7 +1,18 @@ // Some compilers don't have AVX512BW support. Test for them. #include -#if defined(_MSC_VER) +// clang-cl bug doesn't include these headers when pretending to be MSVC +// https://github.com/llvm/llvm-project/blob/e9a294449575a1e1a0daca470f64914695dc9adc/clang/lib/Headers/immintrin.h#L69-L72 +#if defined(_MSC_VER) && defined(__clang__) +#include +#include +#include +#include +#include +#include +#endif + +#if defined(_MSC_VER) && !defined(__clang__) #define INTGEMM_AVX512BW #elif defined(__INTEL_COMPILER) #define INTGEMM_AVX512BW __attribute__ ((target ("avx512f"))) diff --git a/compile_test/avx512vnni.cc b/compile_test/avx512vnni.cc index 1485cde..59035e4 100644 --- a/compile_test/avx512vnni.cc +++ b/compile_test/avx512vnni.cc @@ -1,6 +1,18 @@ #include -#if defined(_MSC_VER) +// clang-cl bug doesn't include these headers when pretending to be MSVC +// https://github.com/llvm/llvm-project/blob/e9a294449575a1e1a0daca470f64914695dc9adc/clang/lib/Headers/immintrin.h#L69-L72 +#if defined(_MSC_VER) && defined(__clang__) +#include +#include +#include +#include +#include +#include +#include +#endif + +#if defined(_MSC_VER) && !defined(__clang__) #elif defined(__INTEL_COMPILER) __attribute__ ((target ("avx512f"))) #else diff --git a/intgemm/intgemm.cc b/intgemm/intgemm.cc index e5fe1b0..d0cfb43 100644 --- a/intgemm/intgemm.cc +++ b/intgemm/intgemm.cc @@ -117,7 +117,7 @@ CPUType GetCPUID() { const CPUType kCPU = GetCPUID(); void UnsupportedCPUError() { -#if defined(_MSC_VER) ? defined(_HAS_EXCEPTIONS) : defined(__EXCEPTIONS) +#if (defined(_MSC_VER) && !defined(__clang__)) ? defined(_HAS_EXCEPTIONS) : defined(__EXCEPTIONS) throw UnsupportedCPU(); #else std::cerr << "intgemm does not support this CPU" << std::endl; diff --git a/intgemm/types.h b/intgemm/types.h index a4b35b4..44fb4e2 100644 --- a/intgemm/types.h +++ b/intgemm/types.h @@ -7,9 +7,22 @@ #endif #include -#if defined(_MSC_VER) || defined(__INTEL_COMPILER) -/* MSVC does not appear to have target attributes but is also fine with just - * using intrinsics anywhere. +// clang-cl bug doesn't include these headers when pretending to be MSVC +// https://github.com/llvm/llvm-project/blob/e9a294449575a1e1a0daca470f64914695dc9adc/clang/lib/Headers/immintrin.h#L69-L72 +#if defined(_MSC_VER) && defined(__clang__) +#include +#include +#include +#include +#include +#include +#include +#endif + +#if (defined(_MSC_VER) && !defined(__clang__)) || defined(__INTEL_COMPILER) +/* Real MSVC does not appear to have target attributes but is also fine with + * just using intrinsics anywhere. clang-cl pretending to be MSVC requires + * target attributes, so it's excluded from the above. * * The Intel compiler has a bug whereby constructors with target attributes do * not link. Like this program doesn't compile with icpc: -- cgit v1.2.3