Mesa (master): util: do not assume MSVC implies SSE

GitLab Mirror gitlab-mirror at kemper.freedesktop.org
Mon Sep 2 14:45:02 UTC 2019


Module: Mesa
Branch: master
Commit: 06099d0e0c200d65a2a956bcdcf414b2802dc9c7
URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=06099d0e0c200d65a2a956bcdcf414b2802dc9c7

Author: Erik Faye-Lund <erik.faye-lund at collabora.com>
Date:   Wed Aug 14 22:28:12 2019 +0200

util: do not assume MSVC implies SSE

This is not true for MSVC on ARM.

Signed-off-by: Erik Faye-Lund <erik.faye-lund at collabora.com>
Reviewed-by: Matt Turner <mattst88 at gmail.com>

---

 src/util/rounding.h | 7 +++----
 1 file changed, 3 insertions(+), 4 deletions(-)

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 <limits.h>
 #include <stdint.h>
 
-#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 <xmmintrin.h>
 #include <emmintrin.h>
 #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




More information about the mesa-commit mailing list