]> git.sesse.net Git - ffmpeg/commitdiff
alsdec: channel sorting
authorPaul B Mahol <onemda@gmail.com>
Fri, 21 Dec 2012 12:51:08 +0000 (12:51 +0000)
committerPaul B Mahol <onemda@gmail.com>
Fri, 21 Dec 2012 14:11:12 +0000 (14:11 +0000)
Signed-off-by: Paul B Mahol <onemda@gmail.com>
libavcodec/alsdec.c

index 1f725a1730561a5de7fba9ebe890a1b0792c6a24..7133bfd9af31b99d7f862205d8332e01efe528a8 100644 (file)
@@ -355,11 +355,16 @@ static av_cold int read_specific_config(ALSDecContext *ctx)
         if (!(sconf->chan_pos = av_malloc(avctx->channels * sizeof(*sconf->chan_pos))))
             return AVERROR(ENOMEM);
 
-        for (i = 0; i < avctx->channels; i++)
+        for (i = 0; i < avctx->channels; i++) {
             sconf->chan_pos[i] = get_bits(&gb, chan_pos_bits);
+            if (sconf->chan_pos[i] >= avctx->channels) {
+                av_log(avctx, AV_LOG_WARNING, "Invalid original channel position.\n");
+                sconf->chan_sort = 0;
+                break;
+            }
+        }
 
         align_get_bits(&gb);
-        // TODO: use this to actually do channel sorting
     } else {
         sconf->chan_sort = 0;
     }
@@ -430,7 +435,6 @@ static int check_specific_config(ALSDecContext *ctx)
 
     MISSING_ERR(sconf->floating,  "Floating point decoding",     AVERROR_PATCHWELCOME);
     MISSING_ERR(sconf->rlslms,    "Adaptive RLS-LMS prediction", AVERROR_PATCHWELCOME);
-    MISSING_ERR(sconf->chan_sort, "Channel sorting",             0);
 
     return error;
 }
@@ -1480,9 +1484,15 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *got_frame_ptr,
     {                                                              \
         int##bps##_t *dest = (int##bps##_t*)ctx->frame.data[0];    \
         shift = bps - ctx->avctx->bits_per_raw_sample;             \
+        if (!sconf->chan_sort) {                                   \
         for (sample = 0; sample < ctx->cur_frame_length; sample++) \
             for (c = 0; c < avctx->channels; c++)                  \
                 *dest++ = ctx->raw_samples[c][sample] << shift;    \
+        } else {                                                                     \
+            for (sample = 0; sample < ctx->cur_frame_length; sample++)               \
+                for (c = 0; c < avctx->channels; c++)                                \
+                    *dest++ = ctx->raw_samples[sconf->chan_pos[c]][sample] << shift; \
+        }                                                                            \
     }
 
     if (ctx->avctx->bits_per_raw_sample <= 16) {