00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021 #include "config.h"
00022
00023 #include "libavutil/arm/cpu.h"
00024 #include "libavutil/attributes.h"
00025 #include "libavcodec/aacpsdsp.h"
00026
00027 void ff_ps_add_squares_neon(float *dst, const float (*src)[2], int n);
00028 void ff_ps_mul_pair_single_neon(float (*dst)[2], float (*src0)[2],
00029 float *src1, int n);
00030 void ff_ps_hybrid_analysis_neon(float (*out)[2], float (*in)[2],
00031 const float (*filter)[8][2],
00032 int stride, int n);
00033 void ff_ps_hybrid_analysis_ileave_neon(float (*out)[32][2], float L[2][38][64],
00034 int i, int len);
00035 void ff_ps_hybrid_synthesis_deint_neon(float out[2][38][64], float (*in)[32][2],
00036 int i, int len);
00037 void ff_ps_decorrelate_neon(float (*out)[2], float (*delay)[2],
00038 float (*ap_delay)[PS_QMF_TIME_SLOTS+PS_MAX_AP_DELAY][2],
00039 const float phi_fract[2], float (*Q_fract)[2],
00040 const float *transient_gain, float g_decay_slope,
00041 int len);
00042 void ff_ps_stereo_interpolate_neon(float (*l)[2], float (*r)[2],
00043 float h[2][4], float h_step[2][4],
00044 int len);
00045
00046 av_cold void ff_psdsp_init_arm(PSDSPContext *s)
00047 {
00048 int cpu_flags = av_get_cpu_flags();
00049
00050 if (have_neon(cpu_flags)) {
00051 s->add_squares = ff_ps_add_squares_neon;
00052 s->mul_pair_single = ff_ps_mul_pair_single_neon;
00053 s->hybrid_synthesis_deint = ff_ps_hybrid_synthesis_deint_neon;
00054 s->hybrid_analysis = ff_ps_hybrid_analysis_neon;
00055 s->stereo_interpolate[0] = ff_ps_stereo_interpolate_neon;
00056 }
00057 }