Commit f80ddd5b authored by Ronald S. Bultje's avatar Ronald S. Bultje Committed by Martin Storsjö

lavu: use intrinsics for emms on systems lacking inline asm support

Signed-off-by: 's avatarDiego Biurrun <diego@biurrun.de>
Signed-off-by: 's avatarMartin Storsjö <martin@martin.st>
parent 620b1e7e
......@@ -1116,6 +1116,7 @@ HAVE_LIST="
MapViewOfFile
memalign
mkstemp
mm_empty
mmap
nanosleep
netinet_sctp_h
......@@ -2743,6 +2744,8 @@ elif enabled x86; then
check_code ld intrin.h "__rdtsc()" && enable rdtsc
check_code ld mmintrin.h "_mm_empty()" && enable mm_empty
enable local_aligned_8 local_aligned_16
# check whether EBP is available on x86
......
......@@ -231,7 +231,7 @@ struct AVDictionary {
# define ONLY_IF_THREADS_ENABLED(x) NULL
#endif
#if HAVE_MMX
#if HAVE_MMX && HAVE_INLINE_ASM
/**
* Empty mmx state.
* this must be called between any dsp function and float/double code.
......@@ -241,8 +241,11 @@ static av_always_inline void emms_c(void)
{
__asm__ volatile ("emms" ::: "memory");
}
#elif HAVE_MMX && HAVE_MM_EMPTY
# include <mmintrin.h>
# define emms_c _mm_empty
#else /* HAVE_MMX */
#define emms_c()
# define emms_c()
#endif /* HAVE_MMX */
#endif /* AVUTIL_INTERNAL_H */
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment