summaryrefslogtreecommitdiff
path: root/libavformat/id3v2.c
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2012-04-01 23:48:36 +0200
committerMichael Niedermayer <michaelni@gmx.at>2012-04-02 00:17:02 +0200
commit49891784ce70456305f19847d4188f07bbc1b6e1 (patch)
treeea5bd40d34743197c8cd4329ba223a8ba49118b3 /libavformat/id3v2.c
parent178f75a5aeb3606bb7947e08f0b89826f5e31f85 (diff)
parent95587d29d73c5cdf39062fde3f21436f8abf3e79 (diff)
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.c18
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) {