{
    "375286238": {
        "crash": [
            "diff --git a/libavcodec/huffyuvdec.c b/libavcodec/huffyuvdec.c\nindex a8ccb724f5..6ca1e1cdbf 100644\n--- a/libavcodec/huffyuvdec.c\n+++ b/libavcodec/huffyuvdec.c\n@@ -723,17 +723,30 @@ static void decode_plane_bitstream(HYuvDecContext *s, int width, int plane)\n                 READ_2PIX_PLANE(s->temp[0][2 * i], s->temp[0][2 * i + 1], plane, OP8bits);\n             }\n         } else {\n-            for(i=0; i<count; i++){\n+            for (i = 0; i < count; i++) {\n                 READ_2PIX_PLANE(s->temp[0][2 * i], s->temp[0][2 * i + 1], plane, OP8bits);\n             }\n+            i = count; // after full read\n         }\n-        if( width&1 && BITS_LEFT(re, &s->gb)>0 ) {\n-            unsigned int index;\n-            int nb_bits, code, n;\n-            UPDATE_CACHE(re, &s->gb);\n-            index = SHOW_UBITS(re, &s->gb, VLC_BITS);\n-            VLC_INTERN(s->temp[0][width-1], s->vlc[plane].table,\n-                       &s->gb, re, VLC_BITS, 3);\n+\n+        // Zero-fill leftover if bits ran out early\n+        for (; i < count; i++) {\n+            s->temp[0][2 * i]     = 0;\n+            s->temp[0][2 * i + 1] = 0;\n+        }\n+\n+        if (width & 1) {\n+            if (BITS_LEFT(re, &s->gb) > 0) {\n+                unsigned int index;\n+                int nb_bits, code, n;\n+                UPDATE_CACHE(re, &s->gb);\n+                index = SHOW_UBITS(re, &s->gb, VLC_BITS);\n+                VLC_INTERN(s->temp[0][width - 1], s->vlc[plane].table,\n+                           &s->gb, re, VLC_BITS, 3);\n+            } else {\n+                // Zero-fill if not enough bits for the last pixel\n+                s->temp[0][width - 1] = 0;\n+            }\n         }\n         CLOSE_READER(re, &s->gb);\n     } else if (s->bps <= 14) {\n@@ -743,32 +756,60 @@ static void decode_plane_bitstream(HYuvDecContext *s, int width, int plane)\n                 READ_2PIX_PLANE(s->temp16[0][2 * i], s->temp16[0][2 * i + 1], plane, OP14bits);\n             }\n         } else {\n-            for(i=0; i<count; i++){\n+            for (i = 0; i < count; i++) {\n                 READ_2PIX_PLANE(s->temp16[0][2 * i], s->temp16[0][2 * i + 1], plane, OP14bits);\n             }\n+            i = count; // after full read\n         }\n-        if( width&1 && BITS_LEFT(re, &s->gb)>0 ) {\n-            unsigned int index;\n-            int nb_bits, code, n;\n-            UPDATE_CACHE(re, &s->gb);\n-            index = SHOW_UBITS(re, &s->gb, VLC_BITS);\n-            VLC_INTERN(s->temp16[0][width-1], s->vlc[plane].table,\n-                       &s->gb, re, VLC_BITS, 3);\n+\n+        // Zero-fill leftover if bits ran out early\n+        for (; i < count; i++) {\n+            s->temp16[0][2 * i]     = 0;\n+            s->temp16[0][2 * i + 1] = 0;\n+        }\n+\n+        if (width & 1) {\n+            if (BITS_LEFT(re, &s->gb) > 0) {\n+                unsigned int index;\n+                int nb_bits, code, n;\n+                UPDATE_CACHE(re, &s->gb);\n+                index = SHOW_UBITS(re, &s->gb, VLC_BITS);\n+                VLC_INTERN(s->temp16[0][width - 1], s->vlc[plane].table,\n+                           &s->gb, re, VLC_BITS, 3);\n+            } else {\n+                // Zero-fill if not enough bits for the last pixel\n+                s->temp16[0][width - 1] = 0;\n+            }\n         }\n         CLOSE_READER(re, &s->gb);\n     } else {\n-        if (count >= (get_bits_left(&s->gb)) / (32 * 2)) {\n-            for (i = 0; i < count && get_bits_left(&s->gb) > 0; i++) {\n+        int bits_left = get_bits_left(&s->gb);\n+        int can_read = bits_left / (32 * 2);\n+        if (count >= can_read) {\n+            int max_count = FFMIN(count, can_read);\n+            for (i = 0; i < max_count && get_bits_left(&s->gb) > 0; i++) {\n                 READ_2PIX_PLANE16(s->temp16[0][2 * i], s->temp16[0][2 * i + 1], plane);\n             }\n         } else {\n-            for(i=0; i<count; i++){\n+            for (i = 0; i < count; i++) {\n                 READ_2PIX_PLANE16(s->temp16[0][2 * i], s->temp16[0][2 * i + 1], plane);\n             }\n+            i = count; // after full read\n+        }\n+\n+        // Zero-fill leftover if bits ran out early\n+        for (; i < count; i++) {\n+            s->temp16[0][2 * i]     = 0;\n+            s->temp16[0][2 * i + 1] = 0;\n         }\n-        if( width&1 && get_bits_left(&s->gb)>0 ) {\n-            int dst = (unsigned)get_vlc2(&s->gb, s->vlc[plane].table, VLC_BITS, 3)<<2;\n-            s->temp16[0][width-1] = dst + get_bits(&s->gb, 2);\n+\n+        if (width & 1) {\n+            if (get_bits_left(&s->gb) > 0) {\n+                int dst = (unsigned)get_vlc2(&s->gb, s->vlc[plane].table, VLC_BITS, 3) << 2;\n+                s->temp16[0][width - 1] = dst + get_bits(&s->gb, 2);\n+            } else {\n+                s->temp16[0][width - 1] = 0;\n+            }\n         }\n     }\n }\n"
        ],
        "non_crash": [],
        "error": []
    },
    "377642312": {
        "crash": [],
        "non_crash": [
            "diff --git a/libavformat/iamf_reader.c b/libavformat/iamf_reader.c\nindex b00bb997ca..cc6b0142da 100644\n--- a/libavformat/iamf_reader.c\n+++ b/libavformat/iamf_reader.c\n@@ -276,6 +276,9 @@ int ff_iamf_read_packet(AVFormatContext *s, IAMFDemuxContext *c,\n         unsigned skip_samples, discard_padding;\n         int ret, len, size, start_pos;\n \n+        /* Zero-initialize the header buffer to avoid reading uninitialized data. */\n+        memset(header, 0, sizeof(header));\n+\n         ret = ffio_ensure_seekback(pb, FFMIN(MAX_IAMF_OBU_HEADER_SIZE, max_size));\n         if (ret < 0)\n             return ret;\n@@ -294,8 +297,8 @@ int ff_iamf_read_packet(AVFormatContext *s, IAMFDemuxContext *c,\n         read += len;\n         if (type >= IAMF_OBU_IA_AUDIO_FRAME && type <= IAMF_OBU_IA_AUDIO_FRAME_ID17) {\n             ret = audio_frame_obu(s, c, pb, pkt, obu_size, type,\n-                                   skip_samples, discard_padding,\n-                                   type == IAMF_OBU_IA_AUDIO_FRAME);\n+                                  skip_samples, discard_padding,\n+                                  type == IAMF_OBU_IA_AUDIO_FRAME);\n             if (ret < 0)\n                 return ret;\n             return read;\n"
        ],
        "error": []
    },
    "377748135": {
        "crash": [],
        "non_crash": [
            "diff --git a/libavcodec/aacsbr_template.c b/libavcodec/aacsbr_template.c\nindex e5bc4d4659..77d50284ae 100644\n--- a/libavcodec/aacsbr_template.c\n+++ b/libavcodec/aacsbr_template.c\n@@ -828,9 +828,20 @@ static void read_sbr_invf(SpectralBandReplication *sbr, GetBitContext *gb,\n {\n     int i;\n \n+    /* Copy previous frame's modes into the \"previous\" (1) array */\n     memcpy(ch_data->bs_invf_mode[1], ch_data->bs_invf_mode[0], 5 * sizeof(uint8_t));\n-    for (i = 0; i < sbr->n_q; i++)\n-        ch_data->bs_invf_mode[0][i] = get_bits(gb, 2);\n+\n+    /* Read new inverse filtering modes */\n+    for (i = 0; i < sbr->n_q; i++) {\n+        unsigned mode = get_bits(gb, 2);\n+        /* Only write into the array up to its size of 5 */\n+        if (i < 5) {\n+            ch_data->bs_invf_mode[0][i] = mode;\n+        } else {\n+            /* In case sbr->n_q > 5, skip bits for alignment but don't write beyond the array */\n+            /* no further action needed here, as we've already read the bits */\n+        }\n+    }\n }\n \n static int read_sbr_envelope(AACDecContext *ac, SpectralBandReplication *sbr, GetBitContext *gb,\n"
        ],
        "error": []
    },
    "377965565": {
        "crash": [
            "diff --git a/libavcodec/refstruct.h b/libavcodec/refstruct.h\nindex c64ad62b6b..ef30e7c4c9 100644\n--- a/libavcodec/refstruct.h\n+++ b/libavcodec/refstruct.h\n@@ -291,7 +291,10 @@ void *ff_refstruct_pool_get(FFRefStructPool *pool);\n  */\n static inline void ff_refstruct_pool_uninit(FFRefStructPool **poolp)\n {\n-    ff_refstruct_unref(poolp);\n+    if (*poolp) {\n+        ff_refstruct_unref(*poolp);\n+        *poolp = NULL;\n+    }\n }\n \n #endif /* AVCODEC_REFSTRUCT_H */\n"
        ],
        "non_crash": [],
        "error": []
    },
    "383825642": {
        "crash": [],
        "non_crash": [
            "diff --git a/libavformat/vqf.c b/libavformat/vqf.c\nindex 4820e0817c..4d48f829ee 100644\n--- a/libavformat/vqf.c\n+++ b/libavformat/vqf.c\n@@ -56,15 +56,26 @@ static void add_metadata(AVFormatContext *s, uint32_t tag,\n {\n     int len = FFMIN(tag_len, remaining);\n     char *buf, key[5] = {0};\n+    int ret;\n \n     if (len == UINT_MAX)\n         return;\n \n-    buf = av_malloc(len+1);\n+    buf = av_malloc(len + 1);\n     if (!buf)\n         return;\n-    avio_read(s->pb, buf, len);\n+\n+    ret = avio_read(s->pb, buf, len);\n+    if (ret < 0) {\n+        av_free(buf);\n+        return;\n+    }\n+    if (ret < len) {\n+        memset(buf + ret, 0, len - ret);\n+    }\n+\n     buf[len] = 0;\n+\n     AV_WL32(key, tag);\n     av_dict_set(&s->metadata, key, buf, AV_DICT_DONT_STRDUP_VAL);\n }\n"
        ],
        "error": []
    },
    "383825645": {
        "crash": [],
        "non_crash": [
            "diff --git a/libavformat/mpegts.c b/libavformat/mpegts.c\nindex 765bedec5c..6f6b95d957 100644\n--- a/libavformat/mpegts.c\n+++ b/libavformat/mpegts.c\n@@ -1889,109 +1889,101 @@ int ff_parse_mpeg2_descriptor(AVFormatContext *fc, AVStream *st, int stream_type\n         }\n         break;\n     case TELETEXT_DESCRIPTOR:\n-        {\n-            uint8_t *extradata = NULL;\n-            int language_count = desc_len / 5, ret;\n+    {\n+        uint8_t *extradata = NULL;\n+        int language_count = desc_len / 5, ret;\n \n-            if (desc_len > 0 && desc_len % 5 != 0)\n-                return AVERROR_INVALIDDATA;\n-\n-            if (language_count > 0) {\n-                /* 4 bytes per language code (3 bytes) with comma or NUL byte should fit language buffer */\n-                av_assert0(language_count <= sizeof(language) / 4);\n+        if (desc_len > 0 && desc_len % 5 != 0)\n+            return AVERROR_INVALIDDATA;\n \n-                if (st->codecpar->extradata == NULL) {\n-                    ret = ff_alloc_extradata(st->codecpar, language_count * 2);\n-                    if (ret < 0)\n-                        return ret;\n-                }\n+        if (language_count > 0) {\n+            av_assert0(language_count <= sizeof(language) / 4);\n \n-                if (st->codecpar->extradata_size < language_count * 2)\n-                    return AVERROR_INVALIDDATA;\n+            if (st->codecpar->extradata == NULL) {\n+                ret = ff_alloc_extradata(st->codecpar, language_count * 2);\n+                if (ret < 0)\n+                    return ret;\n+            }\n \n-                extradata = st->codecpar->extradata;\n+            if (st->codecpar->extradata_size < language_count * 2)\n+                return AVERROR_INVALIDDATA;\n \n-                for (i = 0; i < language_count; i++) {\n-                    language[i * 4 + 0] = get8(pp, desc_end);\n-                    language[i * 4 + 1] = get8(pp, desc_end);\n-                    language[i * 4 + 2] = get8(pp, desc_end);\n-                    language[i * 4 + 3] = ',';\n+            extradata = st->codecpar->extradata;\n \n-                    memcpy(extradata, *pp, 2);\n-                    extradata += 2;\n+            for (i = 0; i < language_count; i++) {\n+                language[i * 4 + 0] = get8(pp, desc_end);\n+                language[i * 4 + 1] = get8(pp, desc_end);\n+                language[i * 4 + 2] = get8(pp, desc_end);\n+                language[i * 4 + 3] = ',';\n \n-                    *pp += 2;\n-                }\n+                memcpy(extradata, *pp, 2);\n+                extradata += 2;\n \n-                language[i * 4 - 1] = 0;\n-                av_dict_set(&st->metadata, \"language\", language, 0);\n-                sti->need_context_update = 1;\n+                *pp += 2;\n             }\n+\n+            language[i * 4 - 1] = 0;\n+            av_dict_set(&st->metadata, \"language\", language, 0);\n+            sti->need_context_update = 1;\n         }\n+    }\n         break;\n     case SUBTITLING_DESCRIPTOR:\n-        {\n-            /* 8 bytes per DVB subtitle substream data:\n-             * ISO_639_language_code (3 bytes),\n-             * subtitling_type (1 byte),\n-             * composition_page_id (2 bytes),\n-             * ancillary_page_id (2 bytes) */\n-            int language_count = desc_len / 8, ret;\n-\n-            if (desc_len > 0 && desc_len % 8 != 0)\n-                return AVERROR_INVALIDDATA;\n-\n-            if (language_count > 1) {\n-                avpriv_request_sample(fc, \"DVB subtitles with multiple languages\");\n-            }\n+    {\n+        int language_count = desc_len / 8, ret;\n \n-            if (language_count > 0) {\n-                uint8_t *extradata;\n+        if (desc_len > 0 && desc_len % 8 != 0)\n+            return AVERROR_INVALIDDATA;\n \n-                /* 4 bytes per language code (3 bytes) with comma or NUL byte should fit language buffer */\n-                av_assert0(language_count <= sizeof(language) / 4);\n+        if (language_count > 1) {\n+            avpriv_request_sample(fc, \"DVB subtitles with multiple languages\");\n+        }\n \n-                if (st->codecpar->extradata == NULL) {\n-                    ret = ff_alloc_extradata(st->codecpar, language_count * 5);\n-                    if (ret < 0)\n-                        return ret;\n-                }\n+        if (language_count > 0) {\n+            uint8_t *extradata;\n \n-                if (st->codecpar->extradata_size < language_count * 5)\n-                    return AVERROR_INVALIDDATA;\n+            av_assert0(language_count <= sizeof(language) / 4);\n \n-                extradata = st->codecpar->extradata;\n-\n-                for (i = 0; i < language_count; i++) {\n-                    language[i * 4 + 0] = get8(pp, desc_end);\n-                    language[i * 4 + 1] = get8(pp, desc_end);\n-                    language[i * 4 + 2] = get8(pp, desc_end);\n-                    language[i * 4 + 3] = ',';\n-\n-                    /* hearing impaired subtitles detection using subtitling_type */\n-                    switch (*pp[0]) {\n-                    case 0x20: /* DVB subtitles (for the hard of hearing) with no monitor aspect ratio criticality */\n-                    case 0x21: /* DVB subtitles (for the hard of hearing) for display on 4:3 aspect ratio monitor */\n-                    case 0x22: /* DVB subtitles (for the hard of hearing) for display on 16:9 aspect ratio monitor */\n-                    case 0x23: /* DVB subtitles (for the hard of hearing) for display on 2.21:1 aspect ratio monitor */\n-                    case 0x24: /* DVB subtitles (for the hard of hearing) for display on a high definition monitor */\n-                    case 0x25: /* DVB subtitles (for the hard of hearing) with plano-stereoscopic disparity for display on a high definition monitor */\n-                        st->disposition |= AV_DISPOSITION_HEARING_IMPAIRED;\n-                        break;\n-                    }\n+            if (st->codecpar->extradata == NULL) {\n+                ret = ff_alloc_extradata(st->codecpar, language_count * 5);\n+                if (ret < 0)\n+                    return ret;\n+            }\n \n-                    extradata[4] = get8(pp, desc_end); /* subtitling_type */\n-                    memcpy(extradata, *pp, 4); /* composition_page_id and ancillary_page_id */\n-                    extradata += 5;\n+            if (st->codecpar->extradata_size < language_count * 5)\n+                return AVERROR_INVALIDDATA;\n \n-                    *pp += 4;\n+            extradata = st->codecpar->extradata;\n+\n+            for (i = 0; i < language_count; i++) {\n+                language[i * 4 + 0] = get8(pp, desc_end);\n+                language[i * 4 + 1] = get8(pp, desc_end);\n+                language[i * 4 + 2] = get8(pp, desc_end);\n+                language[i * 4 + 3] = ',';\n+\n+                switch (*pp[0]) {\n+                case 0x20:\n+                case 0x21:\n+                case 0x22:\n+                case 0x23:\n+                case 0x24:\n+                case 0x25:\n+                    st->disposition |= AV_DISPOSITION_HEARING_IMPAIRED;\n+                    break;\n                 }\n \n-                language[i * 4 - 1] = 0;\n-                av_dict_set(&st->metadata, \"language\", language, 0);\n-                sti->need_context_update = 1;\n+                extradata[4] = get8(pp, desc_end);\n+                memcpy(extradata, *pp, 4);\n+                extradata += 5;\n+\n+                *pp += 4;\n             }\n+\n+            language[i * 4 - 1] = 0;\n+            av_dict_set(&st->metadata, \"language\", language, 0);\n+            sti->need_context_update = 1;\n         }\n+    }\n         break;\n     case ISO_639_LANGUAGE_DESCRIPTOR:\n         for (i = 0; i + 4 <= desc_len; i += 4) {\n@@ -2014,12 +2006,14 @@ int ff_parse_mpeg2_descriptor(AVFormatContext *fc, AVStream *st, int stream_type\n         }\n         if (i && language[0]) {\n             language[i - 1] = 0;\n-            /* don't overwrite language, as it may already have been set by\n-             * another, more specific descriptor (e.g. supplementary audio) */\n             av_dict_set(&st->metadata, \"language\", language, AV_DICT_DONT_OVERWRITE);\n         }\n         break;\n     case REGISTRATION_DESCRIPTOR:\n+        if (desc_end - *pp < 4) {\n+            av_log(fc, AV_LOG_DEBUG, \"Registration descriptor too short\\n\");\n+            return AVERROR_INVALIDDATA;\n+        }\n         st->codecpar->codec_tag = bytestream_get_le32(pp);\n         av_log(fc, AV_LOG_TRACE, \"reg_desc=%.4s\\n\", (char *)&st->codecpar->codec_tag);\n         if (st->codecpar->codec_id == AV_CODEC_ID_NONE || sti->request_probe > 0) {\n@@ -2032,13 +2026,27 @@ int ff_parse_mpeg2_descriptor(AVFormatContext *fc, AVStream *st, int stream_type\n         sti->stream_identifier = 1 + get8(pp, desc_end);\n         break;\n     case METADATA_DESCRIPTOR:\n-        if (get16(pp, desc_end) == 0xFFFF)\n+    {\n+        int val;\n+\n+        if (desc_end - *pp < 2)\n+            return AVERROR_INVALIDDATA;\n+        val = get16(pp, desc_end);\n+        if (val == 0xFFFF) {\n+            if (desc_end - *pp < 4)\n+                return AVERROR_INVALIDDATA;\n             *pp += 4;\n+        }\n+        if (desc_end - *pp < 1)\n+            return AVERROR_INVALIDDATA;\n         if (get8(pp, desc_end) == 0xFF) {\n+            if (desc_end - *pp < 4)\n+                return AVERROR_INVALIDDATA;\n             st->codecpar->codec_tag = bytestream_get_le32(pp);\n             if (st->codecpar->codec_id == AV_CODEC_ID_NONE)\n                 mpegts_find_stream_type(st, st->codecpar->codec_tag, METADATA_types);\n         }\n+    }\n         break;\n     case EXTENSION_DESCRIPTOR: /* DVB extension descriptor */\n         ext_desc_tag = get8(pp, desc_end);\n@@ -2061,7 +2069,7 @@ int ff_parse_mpeg2_descriptor(AVFormatContext *fc, AVStream *st, int stream_type\n                 if (channel_config_code <= 0x8) {\n                     st->codecpar->extradata[9]  = channels = channel_config_code ? channel_config_code : 2;\n                     AV_WL32(&st->codecpar->extradata[12], 48000);\n-                    st->codecpar->extradata[18] = channel_config_code ? (channels > 2) : /* Dual Mono */ 255;\n+                    st->codecpar->extradata[18] = channel_config_code ? (channels > 2) : 255;\n                     st->codecpar->extradata[19] = opus_stream_cnt[channel_config_code];\n                     st->codecpar->extradata[20] = opus_coupled_stream_cnt[channel_config_code];\n                     memcpy(&st->codecpar->extradata[21], opus_channel_map[channels - 1], channels);\n@@ -2080,10 +2088,10 @@ int ff_parse_mpeg2_descriptor(AVFormatContext *fc, AVStream *st, int stream_type\n                 return AVERROR_INVALIDDATA;\n             flags = get8(pp, desc_end);\n \n-            if ((flags & 0x80) == 0) /* mix_type */\n+            if ((flags & 0x80) == 0)\n                 st->disposition |= AV_DISPOSITION_DEPENDENT;\n \n-            switch ((flags >> 2) & 0x1F) { /* editorial_classification */\n+            switch ((flags >> 2) & 0x1F) {\n             case 0x01:\n                 st->disposition |= AV_DISPOSITION_VISUAL_IMPAIRED;\n                 st->disposition |= AV_DISPOSITION_DESCRIPTIONS;\n@@ -2096,7 +2104,7 @@ int ff_parse_mpeg2_descriptor(AVFormatContext *fc, AVStream *st, int stream_type\n                 break;\n             }\n \n-            if (flags & 0x01) { /* language_code_present */\n+            if (flags & 0x01) {\n                 if (desc_len < 4)\n                     return AVERROR_INVALIDDATA;\n                 language[0] = get8(pp, desc_end);\n@@ -2104,50 +2112,43 @@ int ff_parse_mpeg2_descriptor(AVFormatContext *fc, AVStream *st, int stream_type\n                 language[2] = get8(pp, desc_end);\n                 language[3] = 0;\n \n-                /* This language always has to override a possible\n-                 * ISO 639 language descriptor language */\n                 if (language[0])\n                     av_dict_set(&st->metadata, \"language\", language, 0);\n             }\n         }\n         break;\n     case AC3_DESCRIPTOR:\n-        {\n-            int component_type_flag = get8(pp, desc_end) & (1 << 7);\n-            if (component_type_flag) {\n-                int component_type = get8(pp, desc_end);\n-                int service_type_mask = 0x38;  // 0b00111000\n-                int service_type = ((component_type & service_type_mask) >> 3);\n-                if (service_type == 0x02 /* 0b010 */) {\n-                    st->disposition |= AV_DISPOSITION_DESCRIPTIONS;\n-                    av_log(ts ? ts->stream : fc, AV_LOG_DEBUG, \"New track disposition for id %u: %u\\n\", st->id, st->disposition);\n-                }\n+    {\n+        int component_type_flag = get8(pp, desc_end) & (1 << 7);\n+        if (component_type_flag) {\n+            int component_type = get8(pp, desc_end);\n+            int service_type_mask = 0x38;\n+            int service_type = ((component_type & service_type_mask) >> 3);\n+            if (service_type == 0x02) {\n+                st->disposition |= AV_DISPOSITION_DESCRIPTIONS;\n+                av_log(ts ? ts->stream : fc, AV_LOG_DEBUG,\n+                       \"New track disposition for id %u: %u\\n\", st->id, st->disposition);\n             }\n         }\n+    }\n         break;\n     case ENHANCED_AC3_DESCRIPTOR:\n-        {\n-            int component_type_flag = get8(pp, desc_end) & (1 << 7);\n-            if (component_type_flag) {\n-                int component_type = get8(pp, desc_end);\n-                int service_type_mask = 0x38;  // 0b00111000\n-                int service_type = ((component_type & service_type_mask) >> 3);\n-                if (service_type == 0x02 /* 0b010 */) {\n-                    st->disposition |= AV_DISPOSITION_DESCRIPTIONS;\n-                    av_log(ts ? ts->stream : fc, AV_LOG_DEBUG, \"New track disposition for id %u: %u\\n\", st->id, st->disposition);\n-                }\n+    {\n+        int component_type_flag = get8(pp, desc_end) & (1 << 7);\n+        if (component_type_flag) {\n+            int component_type = get8(pp, desc_end);\n+            int service_type_mask = 0x38;\n+            int service_type = ((component_type & service_type_mask) >> 3);\n+            if (service_type == 0x02) {\n+                st->disposition |= AV_DISPOSITION_DESCRIPTIONS;\n+                av_log(ts ? ts->stream : fc, AV_LOG_DEBUG,\n+                       \"New track disposition for id %u: %u\\n\", st->id, st->disposition);\n             }\n         }\n+    }\n         break;\n     case DATA_COMPONENT_DESCRIPTOR:\n-        // STD-B24, fascicle 3, chapter 4 defines private_stream_1\n-        // for captions\n         if (stream_type == STREAM_TYPE_PRIVATE_DATA) {\n-            // This structure is defined in STD-B10, part 1, listing 5.4 and\n-            // part 2, 6.2.20).\n-            // Listing of data_component_ids is in STD-B10, part 2, Annex J.\n-            // Component tag limits are documented in TR-B14, fascicle 2,\n-            // Vol. 3, Section 2, 4.2.8.1\n             int actual_component_tag = sti->stream_identifier - 1;\n             int picked_profile = AV_PROFILE_UNKNOWN;\n             int data_component_id = get16(pp, desc_end);\n@@ -2156,16 +2157,12 @@ int ff_parse_mpeg2_descriptor(AVFormatContext *fc, AVStream *st, int stream_type\n \n             switch (data_component_id) {\n             case 0x0008:\n-                // [0x30..0x37] are component tags utilized for\n-                // non-mobile captioning service (\"profile A\").\n                 if (actual_component_tag >= 0x30 &&\n                     actual_component_tag <= 0x37) {\n                     picked_profile = AV_PROFILE_ARIB_PROFILE_A;\n                 }\n                 break;\n             case 0x0012:\n-                // component tag 0x87 signifies a mobile/partial reception\n-                // (1seg) captioning service (\"profile C\").\n                 if (actual_component_tag == 0x87) {\n                     picked_profile = AV_PROFILE_ARIB_PROFILE_C;\n                 }\n@@ -2188,62 +2185,60 @@ int ff_parse_mpeg2_descriptor(AVFormatContext *fc, AVStream *st, int stream_type\n         }\n         break;\n     case DOVI_VIDEO_STREAM_DESCRIPTOR:\n-        {\n-            uint32_t buf;\n-            AVDOVIDecoderConfigurationRecord *dovi;\n-            size_t dovi_size;\n-            int dependency_pid = -1; // Unset\n+    {\n+        uint32_t buf;\n+        AVDOVIDecoderConfigurationRecord *dovi;\n+        size_t dovi_size;\n+        int dependency_pid = -1;\n \n-            if (desc_end - *pp < 4) // (8 + 8 + 7 + 6 + 1 + 1 + 1) / 8\n-                return AVERROR_INVALIDDATA;\n+        if (desc_end - *pp < 4)\n+            return AVERROR_INVALIDDATA;\n \n-            dovi = av_dovi_alloc(&dovi_size);\n-            if (!dovi)\n-                return AVERROR(ENOMEM);\n+        dovi = av_dovi_alloc(&dovi_size);\n+        if (!dovi)\n+            return AVERROR(ENOMEM);\n \n-            dovi->dv_version_major = get8(pp, desc_end);\n-            dovi->dv_version_minor = get8(pp, desc_end);\n+        dovi->dv_version_major = get8(pp, desc_end);\n+        dovi->dv_version_minor = get8(pp, desc_end);\n+        buf = get16(pp, desc_end);\n+        dovi->dv_profile        = (buf >> 9) & 0x7f;\n+        dovi->dv_level          = (buf >> 3) & 0x3f;\n+        dovi->rpu_present_flag  = (buf >> 2) & 0x01;\n+        dovi->el_present_flag   = (buf >> 1) & 0x01;\n+        dovi->bl_present_flag   =  buf       & 0x01;\n+        if (!dovi->bl_present_flag && desc_end - *pp >= 2) {\n             buf = get16(pp, desc_end);\n-            dovi->dv_profile        = (buf >> 9) & 0x7f;    // 7 bits\n-            dovi->dv_level          = (buf >> 3) & 0x3f;    // 6 bits\n-            dovi->rpu_present_flag  = (buf >> 2) & 0x01;    // 1 bit\n-            dovi->el_present_flag   = (buf >> 1) & 0x01;    // 1 bit\n-            dovi->bl_present_flag   =  buf       & 0x01;    // 1 bit\n-            if (!dovi->bl_present_flag && desc_end - *pp >= 2) {\n-                buf = get16(pp, desc_end);\n-                dependency_pid = buf >> 3; // 13 bits\n-            }\n-            if (desc_end - *pp >= 1) {  // 8 bits\n-                buf = get8(pp, desc_end);\n-                dovi->dv_bl_signal_compatibility_id = (buf >> 4) & 0x0f; // 4 bits\n-                dovi->dv_md_compression = (buf >> 2) & 0x03; // 2 bits\n-            } else {\n-                // 0 stands for None\n-                // Dolby Vision V1.2.93 profiles and levels\n-                dovi->dv_bl_signal_compatibility_id = 0;\n-                dovi->dv_md_compression = AV_DOVI_COMPRESSION_NONE;\n-            }\n-\n-            if (!av_packet_side_data_add(&st->codecpar->coded_side_data,\n-                                         &st->codecpar->nb_coded_side_data,\n-                                         AV_PKT_DATA_DOVI_CONF,\n-                                         (uint8_t *)dovi, dovi_size, 0)) {\n-                av_free(dovi);\n-                return AVERROR(ENOMEM);\n-            }\n+            dependency_pid = buf >> 3;\n+        }\n+        if (desc_end - *pp >= 1) {\n+            buf = get8(pp, desc_end);\n+            dovi->dv_bl_signal_compatibility_id = (buf >> 4) & 0x0f;\n+            dovi->dv_md_compression = (buf >> 2) & 0x03;\n+        } else {\n+            dovi->dv_bl_signal_compatibility_id = 0;\n+            dovi->dv_md_compression = AV_DOVI_COMPRESSION_NONE;\n+        }\n \n-            av_log(fc, AV_LOG_TRACE, \"DOVI, version: %d.%d, profile: %d, level: %d, \"\n-                   \"rpu flag: %d, el flag: %d, bl flag: %d, dependency_pid: %d, \"\n-                   \"compatibility id: %d, compression: %d\\n\",\n-                   dovi->dv_version_major, dovi->dv_version_minor,\n-                   dovi->dv_profile, dovi->dv_level,\n-                   dovi->rpu_present_flag,\n-                   dovi->el_present_flag,\n-                   dovi->bl_present_flag,\n-                   dependency_pid,\n-                   dovi->dv_bl_signal_compatibility_id,\n-                   dovi->dv_md_compression);\n+        if (!av_packet_side_data_add(&st->codecpar->coded_side_data,\n+                                     &st->codecpar->nb_coded_side_data,\n+                                     AV_PKT_DATA_DOVI_CONF,\n+                                     (uint8_t *)dovi, dovi_size, 0)) {\n+            av_free(dovi);\n+            return AVERROR(ENOMEM);\n         }\n+\n+        av_log(fc, AV_LOG_TRACE, \"DOVI, version: %d.%d, profile: %d, level: %d, \"\n+               \"rpu flag: %d, el flag: %d, bl flag: %d, dependency_pid: %d, \"\n+               \"compatibility id: %d, compression: %d\\n\",\n+               dovi->dv_version_major, dovi->dv_version_minor,\n+               dovi->dv_profile, dovi->dv_level,\n+               dovi->rpu_present_flag,\n+               dovi->el_present_flag,\n+               dovi->bl_present_flag,\n+               dependency_pid,\n+               dovi->dv_bl_signal_compatibility_id,\n+               dovi->dv_md_compression);\n+    }\n         break;\n     default:\n         break;\n"
        ],
        "error": []
    },
    "385167047": {
        "crash": [],
        "non_crash": [
            "diff --git a/libavformat/ipmovie.c b/libavformat/ipmovie.c\nindex 5d1748953a..911b7d8920 100644\n--- a/libavformat/ipmovie.c\n+++ b/libavformat/ipmovie.c\n@@ -611,10 +611,18 @@ static int ipmovie_read_header(AVFormatContext *s)\n     unsigned char chunk_preamble[CHUNK_PREAMBLE_SIZE];\n     int chunk_type, i;\n     uint8_t signature_buffer[sizeof(signature)];\n+    int ret;\n \n     ipmovie->avf = s;\n \n-    avio_read(pb, signature_buffer, sizeof(signature_buffer));\n+    ret = avio_read(pb, signature_buffer, sizeof(signature_buffer));\n+    if (ret < (int)sizeof(signature_buffer)) {\n+        if (ret < 0)\n+            return ret;\n+        else\n+            return AVERROR(EIO);\n+    }\n+\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@@ -635,8 +643,7 @@ static int ipmovie_read_header(AVFormatContext *s)\n \n     /* peek ahead to the next chunk-- if it is an init audio chunk, process\n      * it; if it is the first video chunk, this is a silent file */\n-    if (avio_read(pb, chunk_preamble, CHUNK_PREAMBLE_SIZE) !=\n-        CHUNK_PREAMBLE_SIZE)\n+    if (avio_read(pb, chunk_preamble, CHUNK_PREAMBLE_SIZE) != CHUNK_PREAMBLE_SIZE)\n         return AVERROR(EIO);\n     chunk_type = AV_RL16(&chunk_preamble[2]);\n     avio_seek(pb, -CHUNK_PREAMBLE_SIZE, SEEK_CUR);\n@@ -663,7 +670,7 @@ static int ipmovie_read_header(AVFormatContext *s)\n     if (ipmovie->audio_type) {\n         return init_audio(s);\n     } else\n-       s->ctx_flags |= AVFMTCTX_NOHEADER;\n+        s->ctx_flags |= AVFMTCTX_NOHEADER;\n \n     return 0;\n }\n"
        ],
        "error": []
    },
    "385170375": {
        "crash": [
            "diff --git a/libavcodec/rv60dec.c b/libavcodec/rv60dec.c\nindex d0cc10253b..677061484d 100644\n--- a/libavcodec/rv60dec.c\n+++ b/libavcodec/rv60dec.c\n@@ -1519,21 +1519,21 @@ static void decode_4x4_block_dc(GetBitContext * gb, const CoeffVLCs * vlcs, int\n \n static void decode_4x4_block(GetBitContext * gb, const CoeffVLCs * vlcs, int is_luma, int16_t * coeffs, int stride, int q_ac)\n {\n-    int sym0 = get_vlc2(gb, vlcs->l0[!is_luma], 9, 2);\n+    int sym0 = (get_bits_left(gb) >= 9) ? get_vlc2(gb, vlcs->l0[!is_luma], 9, 2) : 0;\n     int grp0 = (sym0 >> 3);\n \n     if (grp0)\n         decode_2x2(gb, vlcs, coeffs, stride, 0, grp0, q_ac);\n \n-    if (sym0 & 4) {\n+    if ((sym0 & 4) && get_bits_left(gb) >= 9) {\n         int grp = get_vlc2(gb, vlcs->l12[!is_luma], 9, 2);\n         decode_2x2(gb, vlcs, coeffs + 2, stride, 0, grp, q_ac);\n     }\n-    if (sym0 & 2) {\n+    if ((sym0 & 2) && get_bits_left(gb) >= 9) {\n         int grp = get_vlc2(gb, vlcs->l12[!is_luma], 9, 2);\n         decode_2x2(gb, vlcs, coeffs + 2*stride, stride, 1, grp, q_ac);\n     }\n-    if (sym0 & 1) {\n+    if ((sym0 & 1) && get_bits_left(gb) >= 9) {\n         int grp = get_vlc2(gb, vlcs->l3[!is_luma], 9, 2);\n         decode_2x2(gb, vlcs, coeffs + 2*stride + 2, stride, 0, grp, q_ac);\n     }\n"
        ],
        "non_crash": [],
        "error": []
    },
    "391962476": {
        "crash": [],
        "non_crash": [
            "diff --git a/libavformat/mlvdec.c b/libavformat/mlvdec.c\nindex 6f4fa80f32..b8a4d0dde0 100644\n--- a/libavformat/mlvdec.c\n+++ b/libavformat/mlvdec.c\n@@ -471,7 +471,14 @@ 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 ((ret = av_new_packet(pkt, size + MAX_HEADER_SIZE)) < 0)\n+\n+    /* Ensure 'size + MAX_HEADER_SIZE' fits in an int before av_new_packet. */\n+    if (size < 0 || size > INT_MAX - MAX_HEADER_SIZE) {\n+        av_log(avctx, AV_LOG_ERROR, \"Invalid packet size: %\"PRId64\"\\\\n\", size);\n+        return AVERROR(EINVAL);\n+    }\n+\n+    if ((ret = av_new_packet(pkt, (int)(size + MAX_HEADER_SIZE))) < 0)\n         return ret;\n \n     bytestream2_init_writer(pb, pkt->data, MAX_HEADER_SIZE);\n"
        ],
        "error": []
    },
    "42537641": {
        "crash": [],
        "non_crash": [
            "diff --git a/libavcodec/cbs_vp9.c b/libavcodec/cbs_vp9.c\nindex 816d06da04..2419d750b5 100644\n--- a/libavcodec/cbs_vp9.c\n+++ b/libavcodec/cbs_vp9.c\n@@ -376,12 +376,14 @@ static int cbs_vp9_split_fragment(CodedBitstreamContext *ctx,\n \n     if ((superframe_header & 0xe0) == 0xc0) {\n         VP9RawSuperframeIndex sfi;\n+        memset(&sfi, 0, sizeof(sfi));\n+\n         GetBitContext gbc;\n         size_t index_size, pos;\n         int i;\n \n         index_size = 2 + (((superframe_header & 0x18) >> 3) + 1) *\n-                          ((superframe_header & 0x07) + 1);\n+                         ((superframe_header & 0x07) + 1);\n \n         if (index_size > frag->data_size)\n             return AVERROR_INVALIDDATA;\n"
        ],
        "error": []
    }
}