From 4f4d1358ae30c2b8588f4dc6b3ef964a048004e8 Mon Sep 17 00:00:00 2001 From: Andrew Wason Date: Wed, 15 Jun 2011 11:09:17 +0200 Subject: [PATCH] Support reading chan atoms with empty channel descriptions. Fixes ticket 263. --- libavformat/isom.c | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/libavformat/isom.c b/libavformat/isom.c index 45ccdd2864..dcc3b74af3 100644 --- a/libavformat/isom.c +++ b/libavformat/isom.c @@ -459,16 +459,18 @@ void ff_mov_read_chan(AVFormatContext *s, int64_t size, AVCodecContext *codec) uint32_t layout_tag; AVIOContext *pb = s->pb; const MovChannelLayout *layouts = mov_channel_layout; - if (size != 12) { + layout_tag = avio_rb32(pb); + size -= 4; + if (layout_tag == 0) { //< kCAFChannelLayoutTag_UseChannelDescriptions // Channel descriptions not implemented av_log_ask_for_sample(s, "Unimplemented container channel layout.\n"); avio_skip(pb, size); return; } - layout_tag = avio_rb32(pb); if (layout_tag == 0x10000) { //< kCAFChannelLayoutTag_UseChannelBitmap codec->channel_layout = avio_rb32(pb); - avio_skip(pb, 4); + size -= 4; + avio_skip(pb, size); return; } while (layouts->channel_layout) { @@ -480,7 +482,7 @@ void ff_mov_read_chan(AVFormatContext *s, int64_t size, AVCodecContext *codec) } if (!codec->channel_layout) av_log(s, AV_LOG_WARNING, "Unknown container channel layout.\n"); - avio_skip(pb, 8); + avio_skip(pb, size); } void ff_mov_write_chan(AVIOContext *pb, int64_t channel_layout)