diff options
author | Justin Ruggles <justin.ruggles@gmail.com> | 2011-10-14 16:47:03 -0400 |
---|---|---|
committer | Justin Ruggles <justin.ruggles@gmail.com> | 2011-10-29 15:06:31 -0400 |
commit | 5e76b8bb760e1d81e5a23552e94c4173b6a625d1 (patch) | |
tree | 8ae9fb463d3821733623f5cf3346c02082d88ce7 | |
parent | 8af33cb38a00a5b80901854d8d6efaa1dba25373 (diff) | |
download | ffmpeg-5e76b8bb760e1d81e5a23552e94c4173b6a625d1.tar.gz |
atrac3: use optimized float_interleave() function for stereo interleaving
-rw-r--r-- | libavcodec/atrac3.c | 26 |
1 files changed, 19 insertions, 7 deletions
diff --git a/libavcodec/atrac3.c b/libavcodec/atrac3.c index f809f9a287..ab14910e28 100644 --- a/libavcodec/atrac3.c +++ b/libavcodec/atrac3.c @@ -41,6 +41,7 @@ #include "dsputil.h" #include "bytestream.h" #include "fft.h" +#include "fmtconvert.h" #include "atrac.h" #include "atrac3data.h" @@ -107,7 +108,7 @@ typedef struct { //@} //@{ /** data buffers */ - float outSamples[2048]; + float *outSamples[2]; uint8_t* decoded_bytes_buffer; float tempBuf[1070]; //@} @@ -120,6 +121,7 @@ typedef struct { //@} FFTContext mdct_ctx; + FmtConvertContext fmt_conv; } ATRAC3Context; static DECLARE_ALIGNED(32, float, mdct_window)[512]; @@ -221,6 +223,8 @@ static av_cold int atrac3_decode_close(AVCodecContext *avctx) av_free(q->pUnits); av_free(q->decoded_bytes_buffer); + av_freep(&q->outSamples[0]); + ff_mdct_end(&q->mdct_ctx); return 0; @@ -824,7 +828,7 @@ static int atrac3_decode_frame(AVCodecContext *avctx, const uint8_t *buf = avpkt->data; int buf_size = avpkt->size; ATRAC3Context *q = avctx->priv_data; - int result = 0, i; + int result = 0; const uint8_t* databuf; float *samples = data; @@ -843,7 +847,7 @@ static int atrac3_decode_frame(AVCodecContext *avctx, databuf = buf; } - result = decodeFrame(q, databuf, q->channels == 2 ? q->outSamples : samples); + result = decodeFrame(q, databuf, q->channels == 2 ? q->outSamples[0] : samples); if (result != 0) { av_log(NULL,AV_LOG_ERROR,"Frame decoding error!\n"); @@ -852,10 +856,8 @@ static int atrac3_decode_frame(AVCodecContext *avctx, /* interleave */ if (q->channels == 2) { - for (i = 0; i < 1024; i++) { - samples[i*2] = q->outSamples[i]; - samples[i*2+1] = q->outSamples[1024+i]; - } + q->fmt_conv.float_interleave(samples, (const float **)q->outSamples, + 1024, 2); } *data_size = 1024 * q->channels * av_get_bytes_per_sample(avctx->sample_fmt); @@ -1003,6 +1005,7 @@ static av_cold int atrac3_decode_init(AVCodecContext *avctx) } dsputil_init(&dsp, avctx); + ff_fmt_convert_init(&q->fmt_conv, avctx); q->pUnits = av_mallocz(sizeof(channel_unit)*q->channels); if (!q->pUnits) { @@ -1010,6 +1013,15 @@ static av_cold int atrac3_decode_init(AVCodecContext *avctx) return AVERROR(ENOMEM); } + if (avctx->channels > 1) { + q->outSamples[0] = av_mallocz(1024 * 2 * sizeof(*q->outSamples[0])); + q->outSamples[1] = q->outSamples[0] + 1024; + if (!q->outSamples[0]) { + atrac3_decode_close(avctx); + return AVERROR(ENOMEM); + } + } + avctx->sample_fmt = AV_SAMPLE_FMT_FLT; return 0; } |