diff options
author | Peter Ross <pross@xvid.org> | 2014-04-04 22:07:36 +1100 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2014-04-04 17:11:47 +0200 |
commit | 8348bd198ff8ef2ad366ac7ad959193ef845d468 (patch) | |
tree | dce316fb22f5fa45815b172dd2c46e62402f1850 /libavformat/wtvdec.c | |
parent | 0f629823355680802320ee7be52af7f4e1b3e0b3 (diff) | |
download | ffmpeg-8348bd198ff8ef2ad366ac7ad959193ef845d468.tar.gz |
avformat/wtvdec: ignore MPEG2VIDEO extradata when count is invalid
Fixes ticket #3522.
Signed-off-by: Peter Ross <pross@xvid.org>
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavformat/wtvdec.c')
-rw-r--r-- | libavformat/wtvdec.c | 24 |
1 files changed, 14 insertions, 10 deletions
diff --git a/libavformat/wtvdec.c b/libavformat/wtvdec.c index 45e6b4ae8f..bf27f291e7 100644 --- a/libavformat/wtvdec.c +++ b/libavformat/wtvdec.c @@ -635,7 +635,7 @@ static AVStream * new_stream(AVFormatContext *s, AVStream *st, int sid, int code */ static AVStream * parse_media_type(AVFormatContext *s, AVStream *st, int sid, ff_asf_guid mediatype, ff_asf_guid subtype, - ff_asf_guid formattype, int size) + ff_asf_guid formattype, uint64_t size) { WtvContext *wtv = s->priv_data; AVIOContext *pb = wtv->pb; @@ -693,16 +693,20 @@ static AVStream * parse_media_type(AVFormatContext *s, AVStream *st, int sid, int consumed = parse_videoinfoheader2(s, st); avio_skip(pb, FFMAX(size - consumed, 0)); } else if (!ff_guidcmp(formattype, ff_format_mpeg2_video)) { - int consumed = parse_videoinfoheader2(s, st); - int count; - avio_skip(pb, 4); - count = avio_rl32(pb); - avio_skip(pb, 12); - if (count && ff_get_extradata(st->codec, pb, count) < 0) { - ff_free_stream(s, st); - return NULL; + uint64_t consumed = parse_videoinfoheader2(s, st); + if (size - consumed >= 20) { + uint32_t count; + consumed += 20; + avio_skip(pb, 4); + count = avio_rl32(pb); + count = FFMIN(count, size - consumed); + avio_skip(pb, 12); + if (count && ff_get_extradata(st->codec, pb, count) < 0) { + ff_free_stream(s, st); + return NULL; + } + consumed += count; } - consumed += 20 + count; avio_skip(pb, FFMAX(size - consumed, 0)); } else { if (ff_guidcmp(formattype, ff_format_none)) |