{
    "id": "377642312",
    "link": "https://issues.oss-fuzz.com/issues/377642312",
    "title": "MemorySanitizer: use-of-uninitialized-value in ff_iamf_parse_obu_header",
    "parent_of_fix_commit": "b5daaa1503fd149a8e6c4964266ceb93fd7d09cd",
    "crashes": [
        {
            "crash-report-data": "MemorySanitizer: use-of-uninitialized-value\n    #0 0x5654bb0a88a7 in ff_iamf_parse_obu_header libavformat/iamf_parse.c\n    #1 0x5654bb0b1b24 in ff_iamf_read_packet libavformat/iamf_reader.c:286:15\n    #2 0x5654bae04a70 in iamf_read_packet libavformat/iamfdec.c:168:11\n    #3 0x5654bad69bb3 in ff_read_packet libavformat/demux.c:646:15\n    #4 0x5654bad6cbb0 in read_frame_internal libavformat/demux.c:1335:15\n    #5 0x5654bad6c2b4 in av_read_frame libavformat/demux.c:1549:17\n    #6 0x5654bacb23b9 in LLVMFuzzerTestOneInput tools/target_dem_fuzzer.c:212:15\n    #7 0x5654baba7880 in fuzzer::Fuzzer::ExecuteCallback(unsigned char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:614:13\n    #8 0x5654bab92af5 in fuzzer::RunOneTest(fuzzer::Fuzzer*, char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:327:6\n    #9 0x5654bab9858f in fuzzer::FuzzerDriver(int*, char***, int (*)(unsigned char const*, unsigned long)) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:862:9\n    #10 0x5654babc3832 in main /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerMain.cpp:20:10\n    #11 0x7f0104c80082 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24082) (BuildId: 0323ab4806bee6f846d9ad4bccfc29afdca49a58)\n    #12 0x5654bab8acdd in _start (/out/ffmpeg_dem_IAMF_fuzzer+0x462cdd)\n\nDEDUP_TOKEN: ff_iamf_parse_obu_header--ff_iamf_read_packet--iamf_read_packet\n  Uninitialized value was created by an allocation of 'header' in the stack frame\n    #0 0x5654bb0b18fe in ff_iamf_read_packet libavformat/iamf_reader.c:273:9\n\nDEDUP_TOKEN: ff_iamf_read_packet",
            "kernel-source-commit": "b5daaa1503fd149a8e6c4964266ceb93fd7d09cd"
        }
    ],
    "patch": "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",
    "patch_modified_files": [
        "libavformat/iamf_reader.c"
    ],
    "sanitizer": "memory",
    "engine": "libfuzzer",
    "target": "ffmpeg_dem_IAMF_fuzzer"
}
