[FFmpeg-cvslog] atrac3: use optimized float_interleave() function for stereo interleaving

Justin Ruggles git at videolan.org
Sun Oct 30 02:04:15 CEST 2011


ffmpeg | branch: master | Justin Ruggles <justin.ruggles at gmail.com> | Fri Oct 14 16:47:03 2011 -0400| [5e76b8bb760e1d81e5a23552e94c4173b6a625d1] | committer: Justin Ruggles

atrac3: use optimized float_interleave() function for stereo interleaving

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=5e76b8bb760e1d81e5a23552e94c4173b6a625d1
---

 libavcodec/atrac3.c |   26 +++++++++++++++++++-------
 1 files changed, 19 insertions(+), 7 deletions(-)

diff --git a/libavcodec/atrac3.c b/libavcodec/atrac3.c
index f809f9a..ab14910 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;
 }



More information about the ffmpeg-cvslog mailing list