diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2012-04-01 23:48:36 +0200 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2012-04-02 00:17:02 +0200 |
commit | 49891784ce70456305f19847d4188f07bbc1b6e1 (patch) | |
tree | ea5bd40d34743197c8cd4329ba223a8ba49118b3 /libavformat/id3v2.c | |
parent | 178f75a5aeb3606bb7947e08f0b89826f5e31f85 (diff) | |
parent | 95587d29d73c5cdf39062fde3f21436f8abf3e79 (diff) | |
download | ffmpeg-49891784ce70456305f19847d4188f07bbc1b6e1.tar.gz |
Merge remote-tracking branch 'qatar/master'
* qatar/master:
vsrc_buffer: allow buffering arbitrary number of frames.
vf_scale: avoid a pointless memcpy in no-op conversion.
avfiltergraph: try to reduce format conversions in filters.
avfiltergraph: add an AVClass to AVFilterGraph on next major bump.
id3v2: fix skipping extended header in id3v2.4
Conflicts:
libavfilter/vf_scale.c
libavfilter/vsrc_buffer.c
libavformat/id3v2.c
Merged-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavformat/id3v2.c')
-rw-r--r-- | libavformat/id3v2.c | 18 |
1 files changed, 9 insertions, 9 deletions
diff --git a/libavformat/id3v2.c b/libavformat/id3v2.c index 16eff7e27d..1352b57b63 100644 --- a/libavformat/id3v2.c +++ b/libavformat/id3v2.c @@ -577,21 +577,21 @@ static void ff_id3v2_parse(AVFormatContext *s, int len, uint8_t version, uint8_t unsync = flags & 0x80; - /* Extended header present, just skip over it */ - if (isv34 && flags & 0x40) { - int size = get_size(s->pb, 4); - if (size < 6) { - reason = "extended header too short."; + if (isv34 && flags & 0x40) { /* Extended header present, just skip over it */ + int extlen = get_size(s->pb, 4); + if (version == 4) + extlen -= 4; // in v2.4 the length includes the length field we just read + + if (extlen < 0) { + reason = "invalid extended header length"; goto error; } - len -= size; + avio_skip(s->pb, extlen); + len -= extlen + 4; if (len < 0) { reason = "extended header too long."; goto error; } - /* already seeked past size, skip the reset */ - size -= 4; - avio_skip(s->pb, size); } while (len >= taghdrlen) { |