FFmpeg
emms.h
Go to the documentation of this file.
1 /*
2  * This file is part of FFmpeg.
3  *
4  * FFmpeg is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Lesser General Public
6  * License as published by the Free Software Foundation; either
7  * version 2.1 of the License, or (at your option) any later version.
8  *
9  * FFmpeg is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12  * Lesser General Public License for more details.
13  *
14  * You should have received a copy of the GNU Lesser General Public
15  * License along with FFmpeg; if not, write to the Free Software
16  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17  */
18 
19 #ifndef AVUTIL_EMMS_H
20 #define AVUTIL_EMMS_H
21 
22 #include "config.h"
23 #include "libavutil/attributes.h"
24 
25 #if ARCH_X86
26 
27 void avpriv_emms_asm(void);
28 
29 #if HAVE_MMX_INLINE
30 #ifndef __MMX__
31 #include "libavutil/cpu.h"
32 #endif
33 
34 # define emms_c emms_c
35 /**
36  * Empty mmx state.
37  * this must be called between any dsp function and float/double code.
38  * for example sin(); dsp->idct_put(); emms_c(); cos()
39  * Note, *alloc() and *free() also use float code in some libc implementations
40  * thus this also applies to them or any function using them.
41  */
42 static av_always_inline void emms_c(void)
43 {
44 /* Some inlined functions may also use mmx instructions regardless of
45  * runtime cpuflags. With that in mind, we unconditionally empty the
46  * mmx state if the target cpu chosen at configure time supports it.
47  */
48 #if !defined(__MMX__)
50 #endif
51  __asm__ volatile ("emms" ::: "memory");
52 }
53 #elif HAVE_MMX && HAVE_MM_EMPTY
54 # include <mmintrin.h>
55 # define emms_c _mm_empty
56 #elif HAVE_MMX_EXTERNAL
57 # define emms_c avpriv_emms_asm
58 #endif /* HAVE_MMX_INLINE */
59 
60 #endif /* ARCH_X86 */
61 
62 #ifndef emms_c
63 # define emms_c() do {} while(0)
64 #endif
65 
66 #endif /* AVUTIL_EMMS_H */
av_get_cpu_flags
int av_get_cpu_flags(void)
Return the flags which specify extensions supported by the CPU.
Definition: cpu.c:103
emms_c
#define emms_c()
Definition: emms.h:63
cpu.h
attributes.h
av_always_inline
#define av_always_inline
Definition: attributes.h:49
__asm__
__asm__(".macro parse_r var r\n\t" "\\var = -1\n\t" _IFC_REG(0) _IFC_REG(1) _IFC_REG(2) _IFC_REG(3) _IFC_REG(4) _IFC_REG(5) _IFC_REG(6) _IFC_REG(7) _IFC_REG(8) _IFC_REG(9) _IFC_REG(10) _IFC_REG(11) _IFC_REG(12) _IFC_REG(13) _IFC_REG(14) _IFC_REG(15) _IFC_REG(16) _IFC_REG(17) _IFC_REG(18) _IFC_REG(19) _IFC_REG(20) _IFC_REG(21) _IFC_REG(22) _IFC_REG(23) _IFC_REG(24) _IFC_REG(25) _IFC_REG(26) _IFC_REG(27) _IFC_REG(28) _IFC_REG(29) _IFC_REG(30) _IFC_REG(31) ".iflt \\var\n\t" ".error \"Unable to parse register name \\r\"\n\t" ".endif\n\t" ".endm")
AV_CPU_FLAG_MMX
#define AV_CPU_FLAG_MMX
standard MMX
Definition: cpu.h:29