Index: source/libvpx/vp9/common/vp9_systemdependent.h |
=================================================================== |
--- source/libvpx/vp9/common/vp9_systemdependent.h (revision 251189) |
+++ source/libvpx/vp9/common/vp9_systemdependent.h (working copy) |
@@ -11,15 +11,19 @@ |
#ifndef VP9_COMMON_VP9_SYSTEMDEPENDENT_H_ |
#define VP9_COMMON_VP9_SYSTEMDEPENDENT_H_ |
+#ifdef _MSC_VER |
+# if _MSC_VER > 1310 && (defined(_M_X64) || defined(_M_IX86)) |
+# include <intrin.h> |
+# define USE_MSC_INTRIN |
+# endif |
+# include <math.h> |
+# define snprintf _snprintf |
+#endif |
+ |
#ifdef __cplusplus |
extern "C" { |
#endif |
-#ifdef _MSC_VER |
-#include <math.h> |
-#define snprintf _snprintf |
-#endif |
- |
#include "./vpx_config.h" |
#if ARCH_X86 || ARCH_X86_64 |
void vpx_reset_mmx_state(void); |
@@ -30,7 +34,7 @@ |
#if defined(_MSC_VER) && _MSC_VER < 1800 |
// round is not defined in MSVC before VS2013. |
-static int round(double x) { |
+static INLINE int round(double x) { |
if (x < 0) |
return (int)ceil(x - 0.5); |
else |
@@ -44,9 +48,7 @@ |
static INLINE int get_msb(unsigned int n) { |
return 31 ^ __builtin_clz(n); |
} |
-#elif defined(_MSC_VER) && _MSC_VER > 1310 && \ |
- (defined(_M_X64) || defined(_M_IX86)) |
-#include <intrin.h> |
+#elif defined(USE_MSC_INTRIN) |
#pragma intrinsic(_BitScanReverse) |
static INLINE int get_msb(unsigned int n) { |
@@ -54,6 +56,7 @@ |
_BitScanReverse(&first_set_bit, n); |
return first_set_bit; |
} |
+#undef USE_MSC_INTRIN |
#else |
// Returns (int)floor(log2(n)). n must be > 0. |
static INLINE int get_msb(unsigned int n) { |