From: "Ronald S. Bultje" <[email protected]>
---
configure | 9 +++++++++
libavutil/x86/cpu.c | 11 +++++++++++
2 files changed, 20 insertions(+)
diff --git a/configure b/configure
index 4fc20a2..35d4406 100755
--- a/configure
+++ b/configure
@@ -1092,6 +1092,7 @@ HAVE_LIST="
gettimeofday
gnu_as
ibm_asm
+ immintrin_h
inet_aton
inline_asm
io_h
@@ -1171,6 +1172,7 @@ HAVE_LIST="
windows_h
winsock2_h
xform_asm
+ xgetbv
xmm_clobbers
yasm
"
@@ -2655,6 +2657,13 @@ int main (void) { _mm_empty(); return 0; }
EOF
fi
+if check_header immintrin.h; then
+ check_cc <<EOF && enable xgetbv
+#include <immintrin.h>
+int main (void) { _xgetbv(0); return 0; }
+EOF
+fi
+
_restrict=
for restrict_keyword in restrict __restrict__ __restrict; do
check_cc <<EOF && _restrict=$restrict_keyword && break
diff --git a/libavutil/x86/cpu.c b/libavutil/x86/cpu.c
index 5d77b0c..c6c96f0 100644
--- a/libavutil/x86/cpu.c
+++ b/libavutil/x86/cpu.c
@@ -34,8 +34,19 @@
: "=a" (eax), "=S" (ebx), "=c" (ecx), "=d" (edx) \
: "0" (index))
+#if HAVE_INLINE_ASM
#define xgetbv(index, eax, edx) \
__asm__ (".byte 0x0f, 0x01, 0xd0" : "=a"(eax), "=d"(edx) : "c" (index))
+#elif HAVE_XGETBV
+#include <immintrin.h>
+
+#define xgetbv(index, eax, edx) \
+ do { \
+ uint64_t res = _xgetbv(index); \
+ eax = res; \
+ edx = res >> 32; \
+ } while (0)
+#endif /* HAVE_XGETBV */
#define get_eflags(x) \
__asm__ volatile ("pushfl \n" \
--
1.7.9.5
_______________________________________________
libav-devel mailing list
[email protected]
https://lists.libav.org/mailman/listinfo/libav-devel