Libav
Macros | Functions
cpu.h File Reference
#include "version.h"

Go to the source code of this file.

Macros

#define AV_CPU_FLAG_FORCE   0x80000000 /* force usage of selected flags (OR) */
 
#define AV_CPU_FLAG_MMX   0x0001
 standard MMX More...
 
#define AV_CPU_FLAG_MMXEXT   0x0002
 SSE integer functions or AMD MMX ext. More...
 
#define AV_CPU_FLAG_3DNOW   0x0004
 AMD 3DNOW. More...
 
#define AV_CPU_FLAG_SSE   0x0008
 SSE functions. More...
 
#define AV_CPU_FLAG_SSE2   0x0010
 PIV SSE2 functions. More...
 
#define AV_CPU_FLAG_SSE2SLOW   0x40000000
 SSE2 supported, but usually not faster. More...
 
#define AV_CPU_FLAG_3DNOWEXT   0x0020
 AMD 3DNowExt. More...
 
#define AV_CPU_FLAG_SSE3   0x0040
 Prescott SSE3 functions. More...
 
#define AV_CPU_FLAG_SSE3SLOW   0x20000000
 SSE3 supported, but usually not faster. More...
 
#define AV_CPU_FLAG_SSSE3   0x0080
 Conroe SSSE3 functions. More...
 
#define AV_CPU_FLAG_SSSE3SLOW   0x4000000
 SSSE3 supported, but usually not faster. More...
 
#define AV_CPU_FLAG_ATOM   0x10000000
 Atom processor, some SSSE3 instructions are slower. More...
 
#define AV_CPU_FLAG_SSE4   0x0100
 Penryn SSE4.1 functions. More...
 
#define AV_CPU_FLAG_SSE42   0x0200
 Nehalem SSE4.2 functions. More...
 
#define AV_CPU_FLAG_AVX   0x4000
 AVX functions: requires OS support even if YMM registers aren't used. More...
 
#define AV_CPU_FLAG_AVXSLOW   0x8000000
 AVX supported, but slow when using YMM registers (e.g. Bulldozer) More...
 
#define AV_CPU_FLAG_XOP   0x0400
 Bulldozer XOP functions. More...
 
#define AV_CPU_FLAG_FMA4   0x0800
 Bulldozer FMA4 functions. More...
 
#define AV_CPU_FLAG_CMOV   0x1000
 i686 cmov More...
 
#define AV_CPU_FLAG_AVX2   0x8000
 AVX2 functions: requires OS support even if YMM registers aren't used. More...
 
#define AV_CPU_FLAG_FMA3   0x10000
 Haswell FMA3 functions. More...
 
#define AV_CPU_FLAG_BMI1   0x20000
 Bit Manipulation Instruction Set 1. More...
 
#define AV_CPU_FLAG_BMI2   0x40000
 Bit Manipulation Instruction Set 2. More...
 
#define AV_CPU_FLAG_ALTIVEC   0x0001
 standard More...
 
#define AV_CPU_FLAG_VSX   0x0002
 ISA 2.06. More...
 
#define AV_CPU_FLAG_POWER8   0x0004
 ISA 2.07. More...
 
#define AV_CPU_FLAG_ARMV5TE   (1 << 0)
 
#define AV_CPU_FLAG_ARMV6   (1 << 1)
 
#define AV_CPU_FLAG_ARMV6T2   (1 << 2)
 
#define AV_CPU_FLAG_VFP   (1 << 3)
 
#define AV_CPU_FLAG_VFPV3   (1 << 4)
 
#define AV_CPU_FLAG_NEON   (1 << 5)
 
#define AV_CPU_FLAG_ARMV8   (1 << 6)
 
#define AV_CPU_FLAG_VFP_VM   (1 << 7)
 VFPv2 vector mode, deprecated in ARMv7-A and unavailable in various CPUs implementations. More...
 

Functions

int av_get_cpu_flags (void)
 Return the flags which specify extensions supported by the CPU. More...
 
void av_set_cpu_flags_mask (int mask)
 Set a mask on flags returned by av_get_cpu_flags(). More...
 
int av_parse_cpu_flags (const char *s)
 Parse CPU flags from a string. More...
 
int av_cpu_count (void)
 

Macro Definition Documentation

◆ AV_CPU_FLAG_FORCE

#define AV_CPU_FLAG_FORCE   0x80000000 /* force usage of selected flags (OR) */

Definition at line 26 of file cpu.h.

◆ AV_CPU_FLAG_MMX

#define AV_CPU_FLAG_MMX   0x0001

◆ AV_CPU_FLAG_MMXEXT

#define AV_CPU_FLAG_MMXEXT   0x0002

◆ AV_CPU_FLAG_3DNOW

#define AV_CPU_FLAG_3DNOW   0x0004

AMD 3DNOW.

Definition at line 31 of file cpu.h.

Referenced by ff_apedsp_init_x86(), ff_get_cpu_flags_x86(), ff_huffyuvdsp_init_x86(), and hadamard_func().

◆ AV_CPU_FLAG_SSE

#define AV_CPU_FLAG_SSE   0x0008

SSE functions.

Definition at line 32 of file cpu.h.

Referenced by ff_get_cpu_flags_x86().

◆ AV_CPU_FLAG_SSE2

#define AV_CPU_FLAG_SSE2   0x0010

PIV SSE2 functions.

Definition at line 33 of file cpu.h.

Referenced by ff_get_cpu_flags_x86().

◆ AV_CPU_FLAG_SSE2SLOW

#define AV_CPU_FLAG_SSE2SLOW   0x40000000

SSE2 supported, but usually not faster.

than regular MMX/SSE (e.g. Core1)

Definition at line 34 of file cpu.h.

Referenced by ff_audio_convert_init_x86(), and ff_get_cpu_flags_x86().

◆ AV_CPU_FLAG_3DNOWEXT

#define AV_CPU_FLAG_3DNOWEXT   0x0020

AMD 3DNowExt.

Definition at line 36 of file cpu.h.

Referenced by ff_get_cpu_flags_x86().

◆ AV_CPU_FLAG_SSE3

#define AV_CPU_FLAG_SSE3   0x0040

Prescott SSE3 functions.

Definition at line 37 of file cpu.h.

Referenced by ff_get_cpu_flags_x86().

◆ AV_CPU_FLAG_SSE3SLOW

#define AV_CPU_FLAG_SSE3SLOW   0x20000000

SSE3 supported, but usually not faster.

than regular MMX/SSE (e.g. Core1)

Definition at line 38 of file cpu.h.

Referenced by ff_get_cpu_flags_x86().

◆ AV_CPU_FLAG_SSSE3

#define AV_CPU_FLAG_SSSE3   0x0080

Conroe SSSE3 functions.

Definition at line 40 of file cpu.h.

Referenced by ff_get_cpu_flags_x86().

◆ AV_CPU_FLAG_SSSE3SLOW

#define AV_CPU_FLAG_SSSE3SLOW   0x4000000

SSSE3 supported, but usually not faster.

Definition at line 41 of file cpu.h.

Referenced by ff_get_cpu_flags_x86().

◆ AV_CPU_FLAG_ATOM

#define AV_CPU_FLAG_ATOM   0x10000000

Atom processor, some SSSE3 instructions are slower.

Definition at line 42 of file cpu.h.

Referenced by av_parse_cpu_flags(), ff_ac3dsp_init_x86(), ff_audiodsp_init_x86(), ff_get_cpu_flags_x86(), and ff_volume_init_x86().

◆ AV_CPU_FLAG_SSE4

#define AV_CPU_FLAG_SSE4   0x0100

Penryn SSE4.1 functions.

Definition at line 43 of file cpu.h.

Referenced by ff_get_cpu_flags_x86().

◆ AV_CPU_FLAG_SSE42

#define AV_CPU_FLAG_SSE42   0x0200

Nehalem SSE4.2 functions.

Definition at line 44 of file cpu.h.

Referenced by ff_apedsp_init_x86(), and ff_get_cpu_flags_x86().

◆ AV_CPU_FLAG_AVX

#define AV_CPU_FLAG_AVX   0x4000

AVX functions: requires OS support even if YMM registers aren't used.

Definition at line 45 of file cpu.h.

Referenced by ff_get_cpu_flags_x86().

◆ AV_CPU_FLAG_AVXSLOW

#define AV_CPU_FLAG_AVXSLOW   0x8000000

AVX supported, but slow when using YMM registers (e.g. Bulldozer)

Definition at line 46 of file cpu.h.

Referenced by ff_get_cpu_flags_x86(), and ff_synth_filter_init_x86().

◆ AV_CPU_FLAG_XOP

#define AV_CPU_FLAG_XOP   0x0400

Bulldozer XOP functions.

Definition at line 47 of file cpu.h.

Referenced by ff_get_cpu_flags_x86().

◆ AV_CPU_FLAG_FMA4

#define AV_CPU_FLAG_FMA4   0x0800

Bulldozer FMA4 functions.

Definition at line 48 of file cpu.h.

Referenced by ff_get_cpu_flags_x86().

◆ AV_CPU_FLAG_CMOV

#define AV_CPU_FLAG_CMOV   0x1000

i686 cmov

Definition at line 49 of file cpu.h.

Referenced by av_parse_cpu_flags(), ff_get_cpu_flags_x86(), ff_h264dsp_init_x86(), ff_huffyuvdsp_init_x86(), and PRED4x4().

◆ AV_CPU_FLAG_AVX2

#define AV_CPU_FLAG_AVX2   0x8000

AVX2 functions: requires OS support even if YMM registers aren't used.

Definition at line 50 of file cpu.h.

Referenced by ff_get_cpu_flags_x86().

◆ AV_CPU_FLAG_FMA3

#define AV_CPU_FLAG_FMA3   0x10000

Haswell FMA3 functions.

Definition at line 51 of file cpu.h.

Referenced by ff_get_cpu_flags_x86().

◆ AV_CPU_FLAG_BMI1

#define AV_CPU_FLAG_BMI1   0x20000

Bit Manipulation Instruction Set 1.

Definition at line 52 of file cpu.h.

Referenced by av_parse_cpu_flags(), and ff_get_cpu_flags_x86().

◆ AV_CPU_FLAG_BMI2

#define AV_CPU_FLAG_BMI2   0x40000

Bit Manipulation Instruction Set 2.

Definition at line 53 of file cpu.h.

Referenced by ff_get_cpu_flags_x86().

◆ AV_CPU_FLAG_ALTIVEC

#define AV_CPU_FLAG_ALTIVEC   0x0001

◆ AV_CPU_FLAG_VSX

#define AV_CPU_FLAG_VSX   0x0002

ISA 2.06.

Definition at line 56 of file cpu.h.

Referenced by ff_get_cpu_flags_ppc().

◆ AV_CPU_FLAG_POWER8

#define AV_CPU_FLAG_POWER8   0x0004

ISA 2.07.

Definition at line 57 of file cpu.h.

Referenced by ff_get_cpu_flags_ppc().

◆ AV_CPU_FLAG_ARMV5TE

#define AV_CPU_FLAG_ARMV5TE   (1 << 0)

Definition at line 59 of file cpu.h.

Referenced by av_parse_cpu_flags(), and ff_get_cpu_flags_arm().

◆ AV_CPU_FLAG_ARMV6

#define AV_CPU_FLAG_ARMV6   (1 << 1)

Definition at line 60 of file cpu.h.

Referenced by av_parse_cpu_flags(), and ff_get_cpu_flags_arm().

◆ AV_CPU_FLAG_ARMV6T2

#define AV_CPU_FLAG_ARMV6T2   (1 << 2)

Definition at line 61 of file cpu.h.

Referenced by av_parse_cpu_flags(), and ff_get_cpu_flags_arm().

◆ AV_CPU_FLAG_VFP

#define AV_CPU_FLAG_VFP   (1 << 3)

Definition at line 62 of file cpu.h.

Referenced by av_parse_cpu_flags(), ff_get_cpu_flags_aarch64(), and ff_get_cpu_flags_arm().

◆ AV_CPU_FLAG_VFPV3

#define AV_CPU_FLAG_VFPV3   (1 << 4)

Definition at line 63 of file cpu.h.

Referenced by av_parse_cpu_flags(), and ff_get_cpu_flags_arm().

◆ AV_CPU_FLAG_NEON

#define AV_CPU_FLAG_NEON   (1 << 5)

Definition at line 64 of file cpu.h.

Referenced by av_parse_cpu_flags(), ff_get_cpu_flags_aarch64(), and ff_get_cpu_flags_arm().

◆ AV_CPU_FLAG_ARMV8

#define AV_CPU_FLAG_ARMV8   (1 << 6)

Definition at line 65 of file cpu.h.

Referenced by av_parse_cpu_flags(), and ff_get_cpu_flags_aarch64().

◆ AV_CPU_FLAG_VFP_VM

#define AV_CPU_FLAG_VFP_VM   (1 << 7)

VFPv2 vector mode, deprecated in ARMv7-A and unavailable in various CPUs implementations.

Definition at line 66 of file cpu.h.

Referenced by av_parse_cpu_flags().

Function Documentation

◆ av_get_cpu_flags()

int av_get_cpu_flags ( void  )

Return the flags which specify extensions supported by the CPU.

Definition at line 47 of file cpu.c.

Referenced by check_cpu_flag(), ff_ac3dsp_init_arm(), ff_ac3dsp_init_x86(), ff_apedsp_init_arm(), ff_apedsp_init_ppc(), ff_apedsp_init_x86(), ff_audio_convert_init_aarch64(), ff_audio_convert_init_arm(), ff_audio_convert_init_x86(), ff_audio_mix_init_x86(), ff_audio_resample_init_aarch64(), ff_audio_resample_init_arm(), ff_audiodsp_init_arm(), ff_audiodsp_init_ppc(), ff_audiodsp_init_x86(), ff_blockdsp_init_arm(), ff_blockdsp_init_ppc(), ff_blockdsp_init_x86(), ff_bswapdsp_init_x86(), ff_cavsdsp_init_x86(), ff_dcadsp_init_aarch64(), ff_dcadsp_init_arm(), ff_dcadsp_init_x86(), ff_dct_init_x86(), ff_dither_init_x86(), ff_dnxhdenc_init_x86(), ff_fdctdsp_init_ppc(), ff_fdctdsp_init_x86(), ff_fft_fixed_init_arm(), ff_fft_init_aarch64(), ff_fft_init_arm(), ff_fft_init_ppc(), ff_fft_init_x86(), ff_float_dsp_init_aarch64(), ff_float_dsp_init_arm(), ff_float_dsp_init_ppc(), ff_float_dsp_init_x86(), ff_fmt_convert_init_aarch64(), ff_fmt_convert_init_arm(), ff_fmt_convert_init_ppc(), ff_fmt_convert_init_x86(), ff_g722dsp_init_arm(), ff_get_unscaled_swscale_ppc(), ff_gradfun_init_x86(), ff_h263dsp_init_x86(), ff_h264_pred_init_aarch64(), ff_h264_pred_init_arm(), ff_h264chroma_init_aarch64(), ff_h264chroma_init_arm(), ff_h264chroma_init_ppc(), ff_h264chroma_init_x86(), ff_h264dsp_init_aarch64(), ff_h264dsp_init_arm(), ff_h264dsp_init_ppc(), ff_h264dsp_init_x86(), ff_h264qpel_init_aarch64(), ff_h264qpel_init_arm(), ff_h264qpel_init_ppc(), ff_h264qpel_init_x86(), ff_hevc_dsp_init_x86(), ff_hpeldsp_init_aarch64(), ff_hpeldsp_init_arm(), ff_hpeldsp_init_ppc(), ff_hpeldsp_init_x86(), ff_huffyuvdsp_init_ppc(), ff_huffyuvdsp_init_x86(), ff_huffyuvencdsp_init_x86(), ff_idctdsp_init_arm(), ff_idctdsp_init_ppc(), ff_idctdsp_init_x86(), ff_imdct15_init_aarch64(), ff_init_lls_x86(), ff_interlace_init_x86(), ff_lpc_init_x86(), ff_mdct_fixed_init_arm(), ff_mdct_init_aarch64(), ff_mdct_init_arm(), ff_mdct_init_ppc(), ff_mdct_init_x86(), ff_me_cmp_init_arm(), ff_me_cmp_init_ppc(), ff_mlpdsp_init_arm(), ff_mlpdsp_init_x86(), ff_mpadsp_init_aarch64(), ff_mpadsp_init_arm(), ff_mpadsp_init_ppc(), ff_mpadsp_init_x86(), ff_mpegvideodsp_init_x86(), ff_mpegvideoencdsp_init_arm(), ff_mpegvideoencdsp_init_ppc(), ff_mpegvideoencdsp_init_x86(), ff_mpv_common_init_arm(), ff_mpv_common_init_neon(), ff_mpv_common_init_ppc(), ff_mpv_common_init_x86(), ff_mpv_encode_init_x86(), ff_pixblockdsp_init_arm(), ff_pixblockdsp_init_ppc(), ff_pixblockdsp_init_x86(), ff_pngdsp_init_x86(), ff_proresdsp_init_x86(), ff_psdsp_init_arm(), ff_qpeldsp_init_x86(), ff_rdft_init_arm(), ff_rgb2rgb_init_x86(), ff_rv34dsp_init_arm(), ff_rv34dsp_init_x86(), ff_rv40dsp_init_aarch64(), ff_rv40dsp_init_arm(), ff_rv40dsp_init_x86(), ff_sbrdsp_init_arm(), ff_sbrdsp_init_x86(), ff_svq1enc_init_ppc(), ff_svq1enc_init_x86(), ff_sws_init_swscale_ppc(), ff_sws_init_swscale_x86(), ff_synth_filter_init_aarch64(), ff_synth_filter_init_arm(), ff_synth_filter_init_x86(), ff_v210enc_init_x86(), ff_vc1dsp_init_aarch64(), ff_vc1dsp_init_arm(), ff_vc1dsp_init_ppc(), ff_vc1dsp_init_x86(), ff_videodsp_init_aarch64(), ff_videodsp_init_arm(), ff_videodsp_init_x86(), ff_volume_init_x86(), ff_vorbisdsp_init_aarch64(), ff_vorbisdsp_init_arm(), ff_vorbisdsp_init_ppc(), ff_vorbisdsp_init_x86(), ff_vp3dsp_init_arm(), ff_vp3dsp_init_ppc(), ff_vp3dsp_init_x86(), ff_vp6dsp_init_arm(), ff_vp6dsp_init_x86(), ff_vp78dsp_init_arm(), ff_vp78dsp_init_ppc(), ff_vp78dsp_init_x86(), ff_vp8dsp_init_arm(), ff_vp8dsp_init_x86(), ff_vp9dsp_init_x86(), ff_xvid_idct_init_x86(), ff_yadif_init_x86(), ff_yuv2rgb_init_ppc(), ff_yuv2rgb_init_tables_ppc(), ff_yuv2rgb_init_x86(), hadamard_func(), main(), PRED4x4(), sws_init_context(), and swscale().

◆ av_set_cpu_flags_mask()

void av_set_cpu_flags_mask ( int  mask)

Set a mask on flags returned by av_get_cpu_flags().

This function is mainly useful for testing.

Warning
this function is not thread safe.

Definition at line 69 of file cpu.c.

Referenced by check_cpu_flag(), main(), and opt_cpuflags().

◆ av_parse_cpu_flags()

int av_parse_cpu_flags ( const char *  s)

Parse CPU flags from a string.

Returns
a combination of AV_CPU_* flags, negative on error.

Definition at line 75 of file cpu.c.

Referenced by main(), and opt_cpuflags().

◆ av_cpu_count()

int av_cpu_count ( void  )
Returns
the number of logical CPU cores present.

Definition at line 153 of file cpu.c.

Referenced by ff_frame_thread_init(), ff_slice_thread_init(), main(), and thread_init_internal().