From: Erik Faye-Lund Date: Wed, 14 Aug 2019 20:28:12 +0000 (+0200) Subject: util: do not assume MSVC implies SSE X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=06099d0e0c200d65a2a956bcdcf414b2802dc9c7;p=mesa.git util: do not assume MSVC implies SSE This is not true for MSVC on ARM. Signed-off-by: Erik Faye-Lund Reviewed-by: Matt Turner --- diff --git a/src/util/rounding.h b/src/util/rounding.h index 8e302921c9d..d3fe8edb7f8 100644 --- a/src/util/rounding.h +++ b/src/util/rounding.h @@ -29,8 +29,7 @@ #include #include -#if defined(__SSE__) || defined(_MSC_VER) -/* MSVC always has SSE nowadays */ +#if defined(__SSE__) || (defined(_M_IX86_FP) && (_M_IX86_FP >= 1)) || defined(_M_X64) #include #include #endif @@ -96,7 +95,7 @@ _mesa_roundeven(double x) static inline long _mesa_lroundevenf(float x) { -#if defined(__SSE__) || defined(_MSC_VER) +#if defined(__SSE__) || (defined(_M_IX86_FP) && (_M_IX86_FP >= 1)) || defined(_M_X64) #if LONG_MAX == INT64_MAX return _mm_cvtss_si64(_mm_load_ss(&x)); #elif LONG_MAX == INT32_MAX @@ -116,7 +115,7 @@ _mesa_lroundevenf(float x) static inline long _mesa_lroundeven(double x) { -#if defined(__SSE2__) || defined(_MSC_VER) +#if defined(__SSE2__) || (defined(_M_IX86_FP) && (_M_IX86_FP >= 2)) || defined(_M_X64) #if LONG_MAX == INT64_MAX return _mm_cvtsd_si64(_mm_load_sd(&x)); #elif LONG_MAX == INT32_MAX