{
    "383825642": {
        "non_crash": [
            "diff --git a/libavformat/vqf.c b/libavformat/vqf.c\nindex 4820e0817c361092eef09d7d7bbdaf80d95927c7..79deb33744b7ba58f68c455f1e02bde474b8f729 100644 (file)\n--- a/libavformat/vqf.c\n+++ b/libavformat/vqf.c\n@@ -63,7 +63,8 @@ static void add_metadata(AVFormatContext *s, uint32_t tag,\n     buf = av_malloc(len+1);\n     if (!buf)\n         return;\n-    avio_read(s->pb, buf, len);\n+    if (len != avio_read(s->pb, buf, len))\n+        return;\n     buf[len] = 0;\n     AV_WL32(key, tag);\n     av_dict_set(&s->metadata, key, buf, AV_DICT_DONT_STRDUP_VAL);\n\n"
        ]
    },
    "391962476": {
        "non_crash": [
            "diff --git a/libavformat/mlvdec.c b/libavformat/mlvdec.c\nindex 6f4fa80f32bb3694f2a68ee84c181c2a990511d6..44f5c207559b7d9a1ce96b54fda6dd07bfc2d9c3 100644 (file)\n--- a/libavformat/mlvdec.c\n+++ b/libavformat/mlvdec.c\n@@ -471,6 +471,9 @@ static int get_packet_lj92(AVFormatContext *avctx, AVStream *st, AVIOContext *pb\n     uint8_t *stripofs, *matrixofs;\n \n #define MAX_HEADER_SIZE 2048\n+    if ((uint64_t)size > INT32_MAX - MAX_HEADER_SIZE)\n+        return AVERROR_PATCHWELCOME;\n+\n     if ((ret = av_new_packet(pkt, size + MAX_HEADER_SIZE)) < 0)\n         return ret;\n \n@@ -562,10 +565,14 @@ static int read_packet(AVFormatContext *avctx, AVPacket *pkt)\n     avio_skip(pb, 12); //timestamp, frameNumber\n     size -= 12;\n     if (st->codecpar->codec_type == AVMEDIA_TYPE_VIDEO) {\n+        if (size < 8)\n+            return AVERROR_INVALIDDATA;\n         avio_skip(pb, 8); // cropPosX, cropPosY, panPosX, panPosY\n         size -= 8;\n     }\n     space = avio_rl32(pb);\n+    if (size < space + 4LL)\n+        return AVERROR_INVALIDDATA;\n     avio_skip(pb, space);\n     size -= space;\n \n@@ -577,9 +584,7 @@ static int read_packet(AVFormatContext *avctx, AVPacket *pkt)\n         else\n             ret = av_get_packet(pb, pkt, (st->codecpar->width * st->codecpar->height * st->codecpar->bits_per_coded_sample + 7) >> 3);\n     } else { // AVMEDIA_TYPE_AUDIO\n-        if (space > UINT_MAX - 24 || size < (24 + space))\n-            return AVERROR_INVALIDDATA;\n-        ret = av_get_packet(pb, pkt, size - (24 + space));\n+        ret = av_get_packet(pb, pkt, size - 4);\n     }\n \n     if (ret < 0)\n\n"
        ]
    },
    "377642312": {
        "non_crash": [
            "diff --git a/libavformat/iamf_reader.c b/libavformat/iamf_reader.c\nindex 9f3469b64fcbb55536434218a56cdb7e74219ef2..d331e1315e37a5d3d1b0e8c590a242a62ad36849 100644 (file)\n--- a/libavformat/iamf_reader.c\n+++ b/libavformat/iamf_reader.c\n@@ -282,7 +282,7 @@ int ff_iamf_read_packet(AVFormatContext *s, IAMFDemuxContext *c,\n     int read = 0;\n \n     while (1) {\n-        uint8_t header[MAX_IAMF_OBU_HEADER_SIZE + AV_INPUT_BUFFER_PADDING_SIZE];\n+        uint8_t header[MAX_IAMF_OBU_HEADER_SIZE + AV_INPUT_BUFFER_PADDING_SIZE] = {0};\n         enum IAMF_OBU_Type type;\n         unsigned obu_size;\n         unsigned skip_samples, discard_padding;\n@@ -294,6 +294,8 @@ int ff_iamf_read_packet(AVFormatContext *s, IAMFDemuxContext *c,\n         size = avio_read(pb, header, FFMIN(MAX_IAMF_OBU_HEADER_SIZE, max_size));\n         if (size < 0)\n             return size;\n+        if (size != FFMIN(MAX_IAMF_OBU_HEADER_SIZE, max_size))\n+            return AVERROR_INVALIDDATA;\n \n         len = ff_iamf_parse_obu_header(header, size, &obu_size, &start_pos, &type,\n                                        &skip_samples, &discard_padding);\n"
        ]
    },
    "377748135": {
        "non_crash": [
            "diff --git a/libavcodec/aacsbr_template.c b/libavcodec/aacsbr_template.c\nindex 436b549fe70fdb0f78c94412586baa87d595b9cd..9fae44d9a5cbd9dc743255d705ded673db821729 100644 (file)\n--- a/libavcodec/aacsbr_template.c\n+++ b/libavcodec/aacsbr_template.c\n@@ -599,6 +599,7 @@ static int sbr_make_f_derived(AACDecContext *ac, SpectralBandReplication *sbr)\n \n     if (sbr->n_q > 5) {\n         av_log(ac->avctx, AV_LOG_ERROR, \"Too many noise floor scale factors: %d\\n\", sbr->n_q);\n+        sbr->n_q = 1;\n         return -1;\n     }\n \n\n"
        ]
    },
    "383825645": {
        "non_crash": [
            "diff --git a/libavformat/wtvdec.c b/libavformat/wtvdec.c\nindex 730c7fca7837b79cb2d7b010d16f6c03e4d4219d..21c9649869383659e47ff11bf73661708fcf4ec4 100644 (file)\n--- a/libavformat/wtvdec.c\n+++ b/libavformat/wtvdec.c\n@@ -833,7 +833,7 @@ static int parse_chunks(AVFormatContext *s, int mode, int64_t seekts, int *len_p\n             int stream_index = ff_find_stream_index(s, sid);\n             if (stream_index >= 0) {\n                 AVStream *st = s->streams[stream_index];\n-                uint8_t buf[258];\n+                uint8_t buf[258] = {0};\n                 const uint8_t *pbuf = buf;\n                 int buf_size;\n \n"
        ]
    },
    "385170375": {
        "non_crash": [
            "diff --git a/libavcodec/rv60dec.c b/libavcodec/rv60dec.c\nindex 0c2e03d7370ce0f37eb060cb5ffcf7dfa0b67b72..24981015a942bfdf748a4420f8a79a165e88b75c 100644 (file)\n--- a/libavcodec/rv60dec.c\n+++ b/libavcodec/rv60dec.c\n@@ -2257,7 +2257,7 @@ static int decode_slice(AVCodecContext *avctx, void *tdata, int cu_y, int thread\n     thread.avg_linesize[1] = 32;\n     thread.avg_linesize[2] = 32;\n \n-    if ((ret = init_get_bits8(&gb, s->slice[cu_y].data, s->slice[cu_y].size)) < 0)\n+    if ((ret = init_get_bits8(&gb, s->slice[cu_y].data, s->slice[cu_y].data_size)) < 0)\n         return ret;\n \n     for (int cu_x = 0; cu_x < s->cu_width; cu_x++) {\n"
        ]
    },
    "375286238": {
        "non_crash": [
            "diff --git a/libavcodec/huffyuvdec.c b/libavcodec/huffyuvdec.c\nindex a8ccb724f526fa820dece2bea7d43fe6149a38fe..c98904d4972bc79008665a020d5dd16b47a110c7 100644 (file)\n--- a/libavcodec/huffyuvdec.c\n+++ b/libavcodec/huffyuvdec.c\n@@ -783,6 +783,8 @@ static void decode_gray_bitstream(HYuvDecContext *s, int count)\n         for (i = 0; i < count && BITS_LEFT(re, &s->gb) > 0; i++) {\n             READ_2PIX(s->temp[0][2 * i], s->temp[0][2 * i + 1], 0);\n         }\n+        for (; i < count; i++)\n+            s->temp[0][2 * i] = s->temp[0][2 * i + 1] = 0;\n     } else {\n         for (i = 0; i < count; i++) {\n             READ_2PIX(s->temp[0][2 * i], s->temp[0][2 * i + 1], 0);\n"
        ]
    },
    "377965565": {
        "non_crash": [
            "diff --git a/libavcodec/vc1dec.c b/libavcodec/vc1dec.c\nindex 5f1a5bd437ce82336383f89e825c369f21749f15..2c314e7b55b9ab7983f565b2ac2bbb08ef0770c6 100644 (file)\n--- a/libavcodec/vc1dec.c\n+++ b/libavcodec/vc1dec.c\n@@ -788,6 +788,7 @@ static av_cold void vc1_decode_reset(AVCodecContext *avctx)\n     for (i = 0; i < 4; i++)\n         av_freep(&v->sr_rows[i >> 1][i & 1]);\n     ff_mpv_common_end(&v->s);\n+    memset(v->s.block_index, 0, sizeof(v->s.block_index));\n     av_freep(&v->mv_type_mb_plane);\n     av_freep(&v->direct_mb_plane);\n     av_freep(&v->forward_mb_plane);\n\n"
        ]
    },
    "385167047": {
        "non_crash": [
            "diff --git a/libavformat/ipmovie.c b/libavformat/ipmovie.c\nindex 5d1748953ab2237ccbd7105e61d0dc15d7971a18..3701be276f3f5923aeb58febd2c09a2da0896aed 100644 (file)\n--- a/libavformat/ipmovie.c\n+++ b/libavformat/ipmovie.c\n@@ -614,7 +614,8 @@ static int ipmovie_read_header(AVFormatContext *s)\n \n     ipmovie->avf = s;\n \n-    avio_read(pb, signature_buffer, sizeof(signature_buffer));\n+    if (avio_read(pb, signature_buffer, sizeof(signature_buffer)) != sizeof(signature_buffer))\n+        return AVERROR_INVALIDDATA;\n     while (memcmp(signature_buffer, signature, sizeof(signature))) {\n         memmove(signature_buffer, signature_buffer + 1, sizeof(signature_buffer) - 1);\n         signature_buffer[sizeof(signature_buffer) - 1] = avio_r8(pb);\n"
        ]
    }
}