Main Page
Related Pages
Modules
Data Structures
Files
Examples
File List
Globals
libavcodec
arm
fft_init_arm.c
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2009 Mans Rullgard <mans@mansr.com>
3
*
4
* This file is part of Libav.
5
*
6
* Libav is free software; you can redistribute it and/or
7
* modify it under the terms of the GNU Lesser General Public
8
* License as published by the Free Software Foundation; either
9
* version 2.1 of the License, or (at your option) any later version.
10
*
11
* Libav is distributed in the hope that it will be useful,
12
* but WITHOUT ANY WARRANTY; without even the implied warranty of
13
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14
* Lesser General Public License for more details.
15
*
16
* You should have received a copy of the GNU Lesser General Public
17
* License along with Libav; if not, write to the Free Software
18
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19
*/
20
21
#include "
libavcodec/fft.h
"
22
#include "
libavcodec/rdft.h
"
23
#include "
libavcodec/synth_filter.h
"
24
25
void
ff_fft_permute_neon
(
FFTContext
*s,
FFTComplex
*z);
26
void
ff_fft_calc_neon
(
FFTContext
*s,
FFTComplex
*z);
27
28
void
ff_imdct_calc_neon
(
FFTContext
*s,
FFTSample
*output,
const
FFTSample
*input);
29
void
ff_imdct_half_neon
(
FFTContext
*s,
FFTSample
*output,
const
FFTSample
*input);
30
void
ff_mdct_calc_neon
(
FFTContext
*s,
FFTSample
*output,
const
FFTSample
*input);
31
32
void
ff_rdft_calc_neon
(
struct
RDFTContext
*s,
FFTSample
*z);
33
34
void
ff_synth_filter_float_neon
(
FFTContext
*imdct,
35
float
*synth_buf_ptr,
int
*synth_buf_offset,
36
float
synth_buf2[32],
const
float
window[512],
37
float
out[32],
const
float
in[32],
38
float
scale
);
39
40
av_cold
void
ff_fft_init_arm
(
FFTContext
*s)
41
{
42
if
(
HAVE_NEON
) {
43
s->
fft_permute
=
ff_fft_permute_neon
;
44
s->
fft_calc
=
ff_fft_calc_neon
;
45
#if CONFIG_MDCT
46
s->
imdct_calc
=
ff_imdct_calc_neon
;
47
s->
imdct_half
=
ff_imdct_half_neon
;
48
s->
mdct_calc
=
ff_mdct_calc_neon
;
49
s->
mdct_permutation
=
FF_MDCT_PERM_INTERLEAVE
;
50
#endif
51
}
52
}
53
54
#if CONFIG_RDFT
55
av_cold
void
ff_rdft_init_arm
(
RDFTContext
*s)
56
{
57
if
(
HAVE_NEON
)
58
s->
rdft_calc
=
ff_rdft_calc_neon
;
59
}
60
#endif
61
62
#if CONFIG_DCA_DECODER
63
av_cold
void
ff_synth_filter_init_arm
(
SynthFilterContext
*s)
64
{
65
if
(
HAVE_NEON
)
66
s->
synth_filter_float
=
ff_synth_filter_float_neon
;
67
}
68
#endif