{
    "id": "375286238",
    "link": "https://issues.oss-fuzz.com/issues/375286238",
    "parent_of_fix_commit": "a797317ab19d12df8c953dab3de548d14c4ba545",
    "title": "MemorySanitizer: use-of-uninitialized-value in add_left_pred_c",
    "crashes": [
        {
            "crash-report-data": "MemorySanitizer: use-of-uninitialized-value\n    #0 0x562b59bcbafc in add_left_pred_c libavcodec/lossless_videodsp.c:80:5\n    #1 0x562b59bb1303 in decode_slice libavcodec/huffyuvdec.c:1049:33\n    #2 0x562b59bb1303 in decode_frame libavcodec/huffyuvdec.c:1305:15\n    #3 0x562b59b8f64e in decode_simple_internal libavcodec/decode.c:435:16\n    #4 0x562b59b8f64e in decode_simple_receive_frame libavcodec/decode.c:605:15\n    #5 0x562b59b8f64e in ff_decode_receive_frame_internal libavcodec/decode.c:641:15\n    #6 0x562b59b9283d in decode_receive_frame_internal libavcodec/decode.c:658:15\n    #7 0x562b59b925c3 in avcodec_send_packet libavcodec/decode.c:745:15\n    #8 0x562b59b7ca93 in LLVMFuzzerTestOneInput tools/target_dec_fuzzer.c:541:25\n    #9 0x562b59a6f4e0 in fuzzer::Fuzzer::ExecuteCallback(unsigned char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:614:13\n    #10 0x562b59a5a755 in fuzzer::RunOneTest(fuzzer::Fuzzer*, char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:327:6\n    #11 0x562b59a601ef in fuzzer::FuzzerDriver(int*, char***, int (*)(unsigned char const*, unsigned long)) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:862:9\n    #12 0x562b59a8b492 in main /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerMain.cpp:20:10\n    #13 0x7f110514a082 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24082) (BuildId: 0323ab4806bee6f846d9ad4bccfc29afdca49a58)\n    #14 0x562b59a5293d in _start (/out/ffmpeg_AV_CODEC_ID_HYMT_fuzzer+0x1f693d)\n\nDEDUP_TOKEN: add_left_pred_c--decode_slice--decode_frame\n  Uninitialized value was created by a heap allocation\n    #0 0x562b59b12a63 in posix_memalign /src/llvm-project/compiler-rt/lib/msan/msan_interceptors.cpp:162:3\n    #1 0x562b5a328ed7 in av_malloc libavutil/mem.c:107:9\n    #2 0x562b59a38c14 in decode_init libavcodec/huffyuvdec.c:610:22\n    #3 0x562b59b82261 in avcodec_open2 libavcodec/avcodec.c:326:19\n    #4 0x562b59b7bd88 in LLVMFuzzerTestOneInput tools/target_dec_fuzzer.c:467:15\n    #5 0x562b59a6f4e0 in fuzzer::Fuzzer::ExecuteCallback(unsigned char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:614:13\n    #6 0x562b59a5a755 in fuzzer::RunOneTest(fuzzer::Fuzzer*, char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:327:6\n    #7 0x562b59a601ef in fuzzer::FuzzerDriver(int*, char***, int (*)(unsigned char const*, unsigned long)) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:862:9\n    #8 0x562b59a8b492 in main /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerMain.cpp:20:10\n    #9 0x7f110514a082 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24082) (BuildId: 0323ab4806bee6f846d9ad4bccfc29afdca49a58)\n\nDEDUP_TOKEN: ___interceptor_posix_memalign--av_malloc--decode_init",
            "kernel-source-commit": "a797317ab19d12df8c953dab3de548d14c4ba545"
        }
    ],
    "patch": "diff --git a/libavcodec/huffyuvdec.c b/libavcodec/huffyuvdec.c\nindex a8ccb724f526fa820dece2bea7d43fe6149a38fe..c98904d4972bc79008665a020d5dd16b47a110c7 100644 (file)\n--- a/libavcodec/huffyuvdec.c\n+++ b/libavcodec/huffyuvdec.c\n@@ -783,6 +783,8 @@ static void decode_gray_bitstream(HYuvDecContext *s, int count)\n         for (i = 0; i < count && BITS_LEFT(re, &s->gb) > 0; i++) {\n             READ_2PIX(s->temp[0][2 * i], s->temp[0][2 * i + 1], 0);\n         }\n+        for (; i < count; i++)\n+            s->temp[0][2 * i] = s->temp[0][2 * i + 1] = 0;\n     } else {\n         for (i = 0; i < count; i++) {\n             READ_2PIX(s->temp[0][2 * i], s->temp[0][2 * i + 1], 0);\n",
    "patch_modified_files": [
        "libavcodec/huffyuvdec.c"
    ],
    "sanitizer": "memory",
    "engine": "libfuzzer",
    "target": "ffmpeg_AV_CODEC_ID_HYMT_fuzzer"
}
