[FFmpeg-cvslog] alsdec: channel sorting
Paul B Mahol
git at videolan.org
Fri Dec 21 15:51:53 CET 2012
ffmpeg | branch: master | Paul B Mahol <onemda at gmail.com> | Fri Dec 21 12:51:08 2012 +0000| [ae27b70b9d9dfb0c1e09b6dfcd2fd74fffc5bbac] | committer: Paul B Mahol
alsdec: channel sorting
Signed-off-by: Paul B Mahol <onemda at gmail.com>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=ae27b70b9d9dfb0c1e09b6dfcd2fd74fffc5bbac
---
libavcodec/alsdec.c | 16 +++++++++++++---
1 file changed, 13 insertions(+), 3 deletions(-)
diff --git a/libavcodec/alsdec.c b/libavcodec/alsdec.c
index 1f725a1..7133bfd 100644
--- a/libavcodec/alsdec.c
+++ b/libavcodec/alsdec.c
@@ -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) {
More information about the ffmpeg-cvslog
mailing list