{
    "id": "385167047",
    "link": "https://issues.oss-fuzz.com/issues/385167047",
    "parent_of_fix_commit": "06f5ed40f8fceb2542add052c57608121eda2f41",
    "title": "MemorySanitizer: use-of-uninitialized-value in ipmovie_read_header",
    "crashes": [
        {
            "crash-report-data": "WARNING: MemorySanitizer: use-of-uninitialized-value\n    #0 0x560624aaa625 in memcmp /src/llvm-project/compiler-rt/lib/msan/../sanitizer_common/sanitizer_common_interceptors.inc:845:10\n    #1 0x560624c87edf in ipmovie_read_header libavformat/ipmovie.c:618:12\n    #2 0x560624bb68e4 in avformat_open_input libavformat/demux.c:305:20\n    #3 0x560624b0330c in LLVMFuzzerTestOneInput tools/target_dem_fuzzer.c:202:11\n    #4 0x5606249f8840 in fuzzer::Fuzzer::ExecuteCallback(unsigned char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:614:13\n    #5 0x5606249e3ab5 in fuzzer::RunOneTest(fuzzer::Fuzzer*, char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:327:6\n    #6 0x5606249e954f in fuzzer::FuzzerDriver(int*, char***, int (*)(unsigned char const*, unsigned long)) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:862:9\n    #7 0x560624a147f2 in main /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerMain.cpp:20:10\n    #8 0x7f9f714de082 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24082) (BuildId: 0323ab4806bee6f846d9ad4bccfc29afdca49a58)\n    #9 0x5606249dbc9d in _start (/out/ffmpeg_dem_IPMOVIE_fuzzer+0x459c9d)\n\nDEDUP_TOKEN: ___interceptor_memcmp--ipmovie_read_header--avformat_open_input\n  Uninitialized value was created by an allocation of 'signature_buffer' in the stack frame\n    #0 0x560624c87e74 in ipmovie_read_header libavformat/ipmovie.c:613:5\n\nDEDUP_TOKEN: ipmovie_read_header",
            "kernel-source-commit": "06f5ed40f8fceb2542add052c57608121eda2f41"
        }
    ],
    "patch": "diff --git a/libavformat/ipmovie.c b/libavformat/ipmovie.c\nindex 5d1748953ab2237ccbd7105e61d0dc15d7971a18..3701be276f3f5923aeb58febd2c09a2da0896aed 100644 (file)\n--- a/libavformat/ipmovie.c\n+++ b/libavformat/ipmovie.c\n@@ -614,7 +614,8 @@ static int ipmovie_read_header(AVFormatContext *s)\n \n     ipmovie->avf = s;\n \n-    avio_read(pb, signature_buffer, sizeof(signature_buffer));\n+    if (avio_read(pb, signature_buffer, sizeof(signature_buffer)) != sizeof(signature_buffer))\n+        return AVERROR_INVALIDDATA;\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",
    "patch_modified_files": [
        "libavformat/ipmovie.c"
    ],
    "sanitizer": "memory",
    "engine": "libfuzzer",
    "target": "ffmpeg_dem_IPMOVIE_fuzzer"
}
