diff options
author | Mans Rullgard <mans@mansr.com> | 2012-09-11 17:55:11 +0100 |
---|---|---|
committer | Mans Rullgard <mans@mansr.com> | 2012-09-12 23:39:50 +0100 |
commit | 97cb9236cf3c45eb8a8fba8b88bdde6ece3f496f (patch) | |
tree | 82d61b5b9f447f09a61277e34022336833853193 /libavcodec/ac3dsp.c | |
parent | b901c30da606ade7427fbfb0f9651cc5bfb953a7 (diff) | |
download | ffmpeg-97cb9236cf3c45eb8a8fba8b88bdde6ece3f496f.tar.gz |
ac3: move ac3_downmix() from dsputil to ac3dsp
Signed-off-by: Mans Rullgard <mans@mansr.com>
Diffstat (limited to 'libavcodec/ac3dsp.c')
-rw-r--r-- | libavcodec/ac3dsp.c | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/libavcodec/ac3dsp.c b/libavcodec/ac3dsp.c index b751aec902..41f79b9f0f 100644 --- a/libavcodec/ac3dsp.c +++ b/libavcodec/ac3dsp.c @@ -171,6 +171,31 @@ static void ac3_extract_exponents_c(uint8_t *exp, int32_t *coef, int nb_coefs) } } +static void ac3_downmix_c(float (*samples)[256], float (*matrix)[2], + int out_ch, int in_ch, int len) +{ + int i, j; + float v0, v1; + if (out_ch == 2) { + for (i = 0; i < len; i++) { + v0 = v1 = 0.0f; + for (j = 0; j < in_ch; j++) { + v0 += samples[j][i] * matrix[j][0]; + v1 += samples[j][i] * matrix[j][1]; + } + samples[0][i] = v0; + samples[1][i] = v1; + } + } else if (out_ch == 1) { + for (i = 0; i < len; i++) { + v0 = 0.0f; + for (j = 0; j < in_ch; j++) + v0 += samples[j][i] * matrix[j][0]; + samples[0][i] = v0; + } + } +} + av_cold void ff_ac3dsp_init(AC3DSPContext *c, int bit_exact) { c->ac3_exponent_min = ac3_exponent_min_c; @@ -182,6 +207,7 @@ av_cold void ff_ac3dsp_init(AC3DSPContext *c, int bit_exact) c->update_bap_counts = ac3_update_bap_counts_c; c->compute_mantissa_size = ac3_compute_mantissa_size_c; c->extract_exponents = ac3_extract_exponents_c; + c->downmix = ac3_downmix_c; if (ARCH_ARM) ff_ac3dsp_init_arm(c, bit_exact); |