Index: source/libvpx/vpx_ports/x86.h |
diff --git a/source/libvpx/vpx_ports/x86.h b/source/libvpx/vpx_ports/x86.h |
index 2a3ebbe22e8d942f3ef30c2a18799f57061a4c6a..81c2b8b873f34c1814a9f7baad04da0d03ad625d 100644 |
--- a/source/libvpx/vpx_ports/x86.h |
+++ b/source/libvpx/vpx_ports/x86.h |
@@ -13,7 +13,6 @@ |
#define VPX_PORTS_X86_H_ |
#include <stdlib.h> |
#include "vpx_config.h" |
-#include "vpx/vpx_integer.h" |
#ifdef __cplusplus |
extern "C" { |
@@ -105,37 +104,6 @@ void __cpuid(int CPUInfo[4], int info_type); |
#endif |
#endif /* end others */ |
-// NaCl has no support for xgetbv or the raw opcode. |
-#if !defined(__native_client__) && (defined(__i386__) || defined(__x86_64__)) |
-static INLINE uint64_t xgetbv(void) { |
- const uint32_t ecx = 0; |
- uint32_t eax, edx; |
- // Use the raw opcode for xgetbv for compatibility with older toolchains. |
- __asm__ volatile ( |
- ".byte 0x0f, 0x01, 0xd0\n" |
- : "=a"(eax), "=d"(edx) : "c" (ecx)); |
- return ((uint64_t)edx << 32) | eax; |
-} |
-#elif (defined(_M_X64) || defined(_M_IX86)) && \ |
- defined(_MSC_FULL_VER) && _MSC_FULL_VER >= 160040219 // >= VS2010 SP1 |
-#include <immintrin.h> |
-#define xgetbv() _xgetbv(0) |
-#elif defined(_MSC_VER) && defined(_M_IX86) |
-static INLINE uint64_t xgetbv(void) { |
- uint32_t eax_, edx_; |
- __asm { |
- xor ecx, ecx // ecx = 0 |
- // Use the raw opcode for xgetbv for compatibility with older toolchains. |
- __asm _emit 0x0f __asm _emit 0x01 __asm _emit 0xd0 |
- mov eax_, eax |
- mov edx_, edx |
- } |
- return ((uint64_t)edx_ << 32) | eax_; |
-} |
-#else |
-#define xgetbv() 0U // no AVX for older x64 or unrecognized toolchains. |
-#endif |
- |
#define HAS_MMX 0x01 |
#define HAS_SSE 0x02 |
#define HAS_SSE2 0x04 |
@@ -188,17 +156,14 @@ x86_simd_caps(void) { |
if (reg_ecx & BIT(19)) flags |= HAS_SSE4_1; |
- // bits 27 (OSXSAVE) & 28 (256-bit AVX) |
- if (reg_ecx & (BIT(27) | BIT(28))) { |
- if ((xgetbv() & 0x6) == 0x6) { |
- flags |= HAS_AVX; |
+ if (reg_ecx & BIT(28)) flags |= HAS_AVX; |
- /* Get the leaf 7 feature flags. Needed to check for AVX2 support */ |
- cpuid(7, 0, reg_eax, reg_ebx, reg_ecx, reg_edx); |
+ /* Get the leaf 7 feature flags. Needed to check for AVX2 support */ |
+ reg_eax = 7; |
+ reg_ecx = 0; |
+ cpuid(7, 0, reg_eax, reg_ebx, reg_ecx, reg_edx); |
- if (reg_ebx & BIT(5)) flags |= HAS_AVX2; |
- } |
- } |
+ if (reg_ebx & BIT(5)) flags |= HAS_AVX2; |
return flags & mask; |
} |