{
    "id": "383825642",
    "link": "https://issues.oss-fuzz.com/issues/383825642",
    "title": "MemorySanitizer: use-of-uninitialized-value in av_strdup",
    "parent_of_fix_commit": "a518b5540de469ac5d4f96e820462e5ce519c2db",
    "crashes": [
        {
            "kernel-source-commit": "a518b5540de469ac5d4f96e820462e5ce519c2db",
            "crash-report-data": " MemorySanitizer: use-of-uninitialized-value\n    #0 0x558f35c1ed74 in av_strdup libavutil/mem.c:276:22\n    #1 0x558f35bd7782 in av_dict_set libavutil/dict.c:99:22\n    #2 0x558f34e7cd48 in ff_metadata_conv libavformat/metadata.c:53:9\n    #3 0x558f34e7cf0f in ff_metadata_conv_ctx libavformat/metadata.c:63:5\n    #4 0x558f351e2318 in vqf_read_header libavformat/vqf.c:234:5\n    #5 0x558f34e440d4 in avformat_open_input libavformat/demux.c:308:20\n    #6 0x558f34e2d93b in LLVMFuzzerTestOneInput tools/target_dem_fuzzer.c:202:11\n    #7 0x558f34d23690 in fuzzer::Fuzzer::ExecuteCallback(unsigned char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:614:13\n    #8 0x558f34d0e905 in fuzzer::RunOneTest(fuzzer::Fuzzer*, char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:327:6\n    #9 0x558f34d1439f in fuzzer::FuzzerDriver(int*, char***, int (*)(unsigned char const*, unsigned long)) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:862:9\n    #10 0x558f34d3f642 in main /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerMain.cpp:20:10\n    #11 0x7f27e3286082 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24082) (BuildId: 0323ab4806bee6f846d9ad4bccfc29afdca49a58)\n    #12 0x558f34d06aed in _start (/out/ffmpeg_DEMUXER_fuzzer+0x468aed)\n\nDEDUP_TOKEN: av_strdup--av_dict_set--ff_metadata_conv\n  Uninitialized value was created by a heap allocation\n    #0 0x558f34dc6c13 in posix_memalign /src/llvm-project/compiler-rt/lib/msan/msan_interceptors.cpp:162:3\n    #1 0x558f35c1d877 in av_malloc libavutil/mem.c:107:9\n    #2 0x558f351e1bf7 in add_metadata libavformat/vqf.c:63:11\n    #3 0x558f351e1bf7 in vqf_read_header libavformat/vqf.c:167:13\n    #4 0x558f34e440d4 in avformat_open_input libavformat/demux.c:308:20\n    #5 0x558f34e2d93b in LLVMFuzzerTestOneInput tools/target_dem_fuzzer.c:202:11\n    #6 0x558f34d23690 in fuzzer::Fuzzer::ExecuteCallback(unsigned char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:614:13\n    #7 0x558f34d0e905 in fuzzer::RunOneTest(fuzzer::Fuzzer*, char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:327:6\n    #8 0x558f34d1439f in fuzzer::FuzzerDriver(int*, char***, int (*)(unsigned char const*, unsigned long)) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:862:9\n    #9 0x558f34d3f642 in main /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerMain.cpp:20:10\n    #10 0x7f27e3286082 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24082) (BuildId: 0323ab4806bee6f846d9ad4bccfc29afdca49a58)\n\nDEDUP_TOKEN: ___interceptor_posix_memalign--av_malloc--add_metadata\nSUMMARY: MemorySanitizer: use-of-uninitialized-value libavutil/mem.c:276:22 in av_strdup"
        }
    ],
    "patch": "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",
    "patch_modified_files": [
        "libavformat/vqf.c"
    ],
    "sanitizer": "memory",
    "engine": "libfuzzer",
    "target": "ffmpeg_DEMUXER_fuzzer"
}
