]> git.sesse.net Git - ffmpeg/blob - libavcodec/x86/fft_init.c
5554b249efe28796cf40d218e0d4c36b99bb994e
[ffmpeg] / libavcodec / x86 / fft_init.c
1 /*
2  * This file is part of Libav.
3  *
4  * Libav 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  * Libav 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 Libav; if not, write to the Free Software
16  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17  */
18
19 #include "libavutil/cpu.h"
20 #include "libavutil/x86/cpu.h"
21 #include "libavcodec/dsputil.h"
22 #include "libavcodec/dct.h"
23 #include "fft.h"
24
25 av_cold void ff_fft_init_x86(FFTContext *s)
26 {
27     int has_vectors = av_get_cpu_flags();
28 #if ARCH_X86_32
29     if (EXTERNAL_AMD3DNOW(has_vectors)) {
30         /* 3DNow! for K6-2/3 */
31         s->imdct_calc = ff_imdct_calc_3dnow;
32         s->imdct_half = ff_imdct_half_3dnow;
33         s->fft_calc   = ff_fft_calc_3dnow;
34     }
35     if (EXTERNAL_AMD3DNOWEXT(has_vectors)) {
36         /* 3DNowEx for K7 */
37         s->imdct_calc = ff_imdct_calc_3dnowext;
38         s->imdct_half = ff_imdct_half_3dnowext;
39         s->fft_calc   = ff_fft_calc_3dnowext;
40     }
41 #endif
42     if (EXTERNAL_SSE(has_vectors)) {
43         /* SSE for P3/P4/K8 */
44         s->imdct_calc  = ff_imdct_calc_sse;
45         s->imdct_half  = ff_imdct_half_sse;
46         s->fft_permute = ff_fft_permute_sse;
47         s->fft_calc    = ff_fft_calc_sse;
48         s->fft_permutation = FF_FFT_PERM_SWAP_LSBS;
49     }
50     if (EXTERNAL_AVX(has_vectors) && s->nbits >= 5) {
51         /* AVX for SB */
52         s->imdct_half      = ff_imdct_half_avx;
53         s->fft_calc        = ff_fft_calc_avx;
54         s->fft_permutation = FF_FFT_PERM_AVX;
55     }
56 }
57
58 #if CONFIG_DCT
59 av_cold void ff_dct_init_x86(DCTContext *s)
60 {
61     int has_vectors = av_get_cpu_flags();
62     if (EXTERNAL_SSE(has_vectors))
63         s->dct32 = ff_dct32_float_sse;
64     if (EXTERNAL_SSE2(has_vectors))
65         s->dct32 = ff_dct32_float_sse2;
66     if (EXTERNAL_AVX(has_vectors))
67         s->dct32 = ff_dct32_float_avx;
68 }
69 #endif