]> git.sesse.net Git - ffmpeg/commitdiff
lavf/id3v2: fail read_apic on EOF reading mimetype
authorchcunningham <chcunningham@chromium.org>
Fri, 14 Dec 2018 21:44:07 +0000 (13:44 -0800)
committerMichael Niedermayer <michael@niedermayer.cc>
Mon, 17 Dec 2018 17:30:10 +0000 (18:30 +0100)
avio_read may return EOF, leaving the mimetype array unitialized. fail
early when this occurs to avoid using the array in an unitialized state.

Reviewed-by: Tomas Härdin <tjoppen@acc.umu.se>
Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
libavformat/id3v2.c

index bb5c3f811986762dbbce9f6e02265edc5c1eec4a..b43ab1745f27dae3636eff5fb2592d9eea687240 100644 (file)
@@ -591,7 +591,7 @@ static void read_apic(AVFormatContext *s, AVIOContext *pb, int taglen,
                       int isv34)
 {
     int enc, pic_type;
-    char mimetype[64];
+    char mimetype[64] = {0};
     const CodecMime *mime     = ff_id3v2_mime_tags;
     enum AVCodecID id         = AV_CODEC_ID_NONE;
     ID3v2ExtraMetaAPIC *apic  = NULL;
@@ -613,7 +613,9 @@ static void read_apic(AVFormatContext *s, AVIOContext *pb, int taglen,
     if (isv34) {
         taglen -= avio_get_str(pb, taglen, mimetype, sizeof(mimetype));
     } else {
-        avio_read(pb, mimetype, 3);
+        if (avio_read(pb, mimetype, 3) < 0)
+            goto fail;
+
         mimetype[3] = 0;
         taglen    -= 3;
     }