{
    "id": "391962476",
    "parent_of_fix_commit": "2202dcfc0fbee51e0fe280877fedf07e6762f3a4",
    "title": "AddressSanitizer: heap-buffer-overflow in bytestream2_put_le32",
    "link": "https://issues.oss-fuzz.com/issues/391962476",
    "crashes": [
        {
            "kernel-source-commit": "2202dcfc0fbee51e0fe280877fedf07e6762f3a4",
            "crash-report-data": "ERROR: AddressSanitizer: heap-buffer-overflow on address 0x512000000165 at pc 0x55d5d35f17ee bp 0x7ffe8138be80 sp 0x7ffe8138be78\nWRITE of size 4 at 0x512000000165 thread T0\nSCARINESS: 36 (4-byte-write-heap-buffer-overflow)\n    #0 0x55d5d35f17ed in bytestream2_put_le32 libavcodec/bytestream.h:92:1\n    #1 0x55d5d35f17ed in get_packet_lj92 libavformat/mlvdec.c:515:9\n    #2 0x55d5d35eca4a in read_packet libavformat/mlvdec.c:576:19\n    #3 0x55d5d3510add in ff_read_packet libavformat/demux.c:649:15\n    #4 0x55d5d351304a in read_frame_internal libavformat/demux.c:1344:15\n    #5 0x55d5d3519b40 in avformat_find_stream_info libavformat/demux.c:2711:15\n    #6 0x55d5d347eab2 in LLVMFuzzerTestOneInput tools/target_dem_fuzzer.c:207:11\n    #7 0x55d5d3c23eff in main (/out/ffmpeg_dem_MLV_fuzzer+0x9e4eff)\n    #8 0x7fdae7df4082 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24082) (BuildId: 0323ab4806bee6f846d9ad4bccfc29afdca49a58)\n    #9 0x55d5d33a5b8d in _start (/out/ffmpeg_dem_MLV_fuzzer+0x166b8d)\n\nDEDUP_TOKEN: bytestream2_put_le32--get_packet_lj92--read_packet\n0x512000000165 is located 0 bytes after 293-byte region [0x512000000040,0x512000000165)\nallocated by thread T0 here:\n    #0 0x55d5d343ef8c in realloc /src/llvm-project/compiler-rt/lib/asan/asan_malloc_linux.cpp:82:3\n    #1 0x55d5d38a3219 in av_buffer_realloc libavutil/buffer.c:192:25\n    #2 0x55d5d384b7d5 in packet_alloc libavcodec/packet.c:90:11\n    #3 0x55d5d384b7d5 in av_new_packet libavcodec/packet.c:102:15\n    #4 0x55d5d35ee8fa in get_packet_lj92 libavformat/mlvdec.c:474:16\n    #5 0x55d5d35eca4a in read_packet libavformat/mlvdec.c:576:19\n    #6 0x55d5d3510add in ff_read_packet libavformat/demux.c:649:15\n    #7 0x55d5d351304a in read_frame_internal libavformat/demux.c:1344:15\n    #8 0x55d5d3519b40 in avformat_find_stream_info libavformat/demux.c:2711:15\n    #9 0x55d5d347eab2 in LLVMFuzzerTestOneInput tools/target_dem_fuzzer.c:207:11\n    #10 0x55d5d3c23eff in main (/out/ffmpeg_dem_MLV_fuzzer+0x9e4eff)\n\nDEDUP_TOKEN: __interceptor_realloc--av_buffer_realloc--packet_alloc\nSUMMARY: AddressSanitizer: heap-buffer-overflow libavcodec/bytestream.h:92:1 in bytestream2_put_le32\nShadow bytes around the buggy address:\n  0x511ffffffe80: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00\n  0x511fffffff00: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00\n  0x511fffffff80: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00\n  0x512000000000: fa fa fa fa fa fa fa fa 00 00 00 00 00 00 00 00\n  0x512000000080: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00\n=>0x512000000100: 00 00 00 00 00 00 00 00 00 00 00 00[05]fa fa fa\n  0x512000000180: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa\n  0x512000000200: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa\n  0x512000000280: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa\n  0x512000000300: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa\n  0x512000000380: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa\nShadow byte legend (one shadow byte represents 8 application bytes):\n  Addressable:           00\n  Partially addressable: 01 02 03 04 05 06 07\n  Heap left redzone:       fa\n  Freed heap region:       fd\n  Stack left redzone:      f1\n  Stack mid redzone:       f2\n  Stack right redzone:     f3\n  Stack after return:      f5\n  Stack use after scope:   f8\n  Global redzone:          f9\n  Global init order:       f6\n  Poisoned by user:        f7\n  Container overflow:      fc\n  Array cookie:            ac\n  Intra object redzone:    bb\n  ASan internal:           fe\n  Left alloca redzone:     ca\n  Right alloca redzone:    cb\n"
        }
    ],
    "patch": "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",
    "patch_modified_files": [
        "libavformat/mlvdec.c"
    ],
    "sanitizer": "address",
    "engine": "honggfuzz",
    "target": "ffmpeg_dem_MLV_fuzzer"
}
