{
    "id": "383825645",
    "parent_of_fix_commit": "a518b5540de469ac5d4f96e820462e5ce519c2db",
    "link": "https://issues.oss-fuzz.com/issues/383825645",
    "title": "MemorySanitizer: use-of-uninitialized-value in ff_parse_mpeg2_descriptor",
    "crashes": [
        {
            "crash-report-data": "MemorySanitizer: use-of-uninitialized-value\n    #0 0x55da04f0bc53 in ff_parse_mpeg2_descriptor libavformat/mpegts.c:2026:13\n    #1 0x55da0506d400 in parse_chunks libavformat/wtvdec.c:852:17\n    #2 0x55da0506394f in read_header libavformat/wtvdec.c:993:11\n    #3 0x55da04d5c8a4 in avformat_open_input libavformat/demux.c:308:20\n    #4 0x55da04ca915c in LLVMFuzzerTestOneInput tools/target_dem_fuzzer.c:202:11\n    #5 0x55da04b9e690 in fuzzer::Fuzzer::ExecuteCallback(unsigned char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:614:13\n    #6 0x55da04b89905 in fuzzer::RunOneTest(fuzzer::Fuzzer*, char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:327:6\n    #7 0x55da04b8f39f in fuzzer::FuzzerDriver(int*, char***, int (*)(unsigned char const*, unsigned long)) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:862:9\n    #8 0x55da04bba642 in main /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerMain.cpp:20:10\n    #9 0x7f429666c082 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24082) (BuildId: 0323ab4806bee6f846d9ad4bccfc29afdca49a58)\n    #10 0x55da04b81aed in _start (/out/ffmpeg_dem_WTV_fuzzer+0x467aed)\n\nDEDUP_TOKEN: ff_parse_mpeg2_descriptor--parse_chunks--read_header\n  Uninitialized value was stored to memory at\n    #0 0x55da04f0bc4c in ff_parse_mpeg2_descriptor libavformat/mpegts.c:2026:55\n    #1 0x55da0506d400 in parse_chunks libavformat/wtvdec.c:852:17\n    #2 0x55da0506394f in read_header libavformat/wtvdec.c:993:11\n    #3 0x55da04d5c8a4 in avformat_open_input libavformat/demux.c:308:20\n    #4 0x55da04ca915c in LLVMFuzzerTestOneInput tools/target_dem_fuzzer.c:202:11\n    #5 0x55da04b9e690 in fuzzer::Fuzzer::ExecuteCallback(unsigned char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:614:13\n    #6 0x55da04b89905 in fuzzer::RunOneTest(fuzzer::Fuzzer*, char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:327:6\n    #7 0x55da04b8f39f in fuzzer::FuzzerDriver(int*, char***, int (*)(unsigned char const*, unsigned long)) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:862:9\n    #8 0x55da04bba642 in main /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerMain.cpp:20:10\n    #9 0x7f429666c082 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24082) (BuildId: 0323ab4806bee6f846d9ad4bccfc29afdca49a58)\n\nDEDUP_TOKEN: ff_parse_mpeg2_descriptor--parse_chunks--read_header\n  Uninitialized value was stored to memory at\n    #0 0x55da04f0b73d in ff_parse_mpeg2_descriptor libavformat/mpegts.c:2023:33\n    #1 0x55da0506d400 in parse_chunks libavformat/wtvdec.c:852:17\n    #2 0x55da0506394f in read_header libavformat/wtvdec.c:993:11\n    #3 0x55da04d5c8a4 in avformat_open_input libavformat/demux.c:308:20\n    #4 0x55da04ca915c in LLVMFuzzerTestOneInput tools/target_dem_fuzzer.c:202:11\n    #5 0x55da04b9e690 in fuzzer::Fuzzer::ExecuteCallback(unsigned char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:614:13\n    #6 0x55da04b89905 in fuzzer::RunOneTest(fuzzer::Fuzzer*, char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:327:6\n    #7 0x55da04b8f39f in fuzzer::FuzzerDriver(int*, char***, int (*)(unsigned char const*, unsigned long)) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:862:9\n    #8 0x55da04bba642 in main /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerMain.cpp:20:10\n    #9 0x7f429666c082 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24082) (BuildId: 0323ab4806bee6f846d9ad4bccfc29afdca49a58)\n\nDEDUP_TOKEN: ff_parse_mpeg2_descriptor--parse_chunks--read_header\n  Uninitialized value was created by an allocation of 'buf' in the stack frame\n    #0 0x55da0506d206 in parse_chunks libavformat/wtvdec.c:836:17\n\nDEDUP_TOKEN: parse_chunks",
            "kernel-source-commit": "a518b5540de469ac5d4f96e820462e5ce519c2db"
        }
    ],
    "patch": "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",
    "patch_modified_files": [
        "libavformat/wtvdec.c"
    ],
    "sanitizer": "memory",
    "engine": "libfuzzer",
    "target": "ffmpeg_dem_WTV_fuzzer"
}
