{
    "id": "377965565",
    "title": "MemorySanitizer: SEGV on unknown address in ff_refstruct_unref",
    "link": "https://issues.oss-fuzz.com/issues/377965565",
    "parent_of_fix_commit": "e25667f9f14fa71d655265905fa91aa39953a17e",
    "crashes": [
        {
            "kernel-source-commit": "e25667f9f14fa71d655265905fa91aa39953a17e",
            "crash-report-data": "MemorySanitizer: SEGV on unknown address (pc 0x55f02342cc81 bp 0x7ffd45431a00 sp 0x7ffd454319b8 T18)\n==18==The signal is caused by a READ memory access.\n==18==Hint: this fault was caused by a dereference of a high value address (see register values below).  Disassemble the provided pc to learn which register was used.\n    #0 0x55f02342cc81 in ff_refstruct_unref libavcodec/refstruct.c:134:9\n    #1 0x55f02389bfab in ff_refstruct_pool_uninit libavcodec/refstruct.h:294:5\n    #2 0x55f02389bfab in free_buffer_pools libavcodec/mpegvideo.c:509:5\n    #3 0x55f02389bfab in ff_mpv_free_context_frame libavcodec/mpegvideo.c:756:5\n    #4 0x55f02389bb09 in ff_mpv_common_end libavcodec/mpegvideo.c:779:5\n    #5 0x55f02326ec9c in vc1_decode_reset libavcodec/vc1dec.c:790:5\n    #6 0x55f0234447a4 in vc1_decode_frame libavcodec/vc1dec.c:1002:9\n    #7 0x55f0233c54d5 in decode_simple_internal libavcodec/decode.c:429:20\n    #8 0x55f0233c54d5 in decode_simple_receive_frame libavcodec/decode.c:600:15\n    #9 0x55f0233c54d5 in decode_receive_frame_internal libavcodec/decode.c:631:15\n    #10 0x55f0233c49ed in avcodec_send_packet libavcodec/decode.c:721:15\n    #11 0x55f0233b2493 in LLVMFuzzerTestOneInput tools/target_dec_fuzzer.c:534:25\n    #12 0x55f0232a4ee0 in fuzzer::Fuzzer::ExecuteCallback(unsigned char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:614:13\n    #13 0x55f023290155 in fuzzer::RunOneTest(fuzzer::Fuzzer*, char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:327:6\n    #14 0x55f023295bef in fuzzer::FuzzerDriver(int*, char***, int (*)(unsigned char const*, unsigned long)) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:862:9\n    #15 0x55f0232c0e92 in main /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerMain.cpp:20:10\n    #16 0x7f658505a082 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24082) (BuildId: 0323ab4806bee6f846d9ad4bccfc29afdca49a58)\n    #17 0x55f02328833d in _start (/out/ffmpeg_AV_CODEC_ID_VC1_fuzzer+0x21333d)\n\nDEDUP_TOKEN: ff_refstruct_unref--ff_refstruct_pool_uninit--free_buffer_pools\nMemorySanitizer can not provide additional info.\nSUMMARY: MemorySanitizer: SEGV libavcodec/refstruct.c:134:9 in ff_refstruct_unref"
        }
    ],
    "patch": "diff --git a/libavcodec/vc1dec.c b/libavcodec/vc1dec.c\nindex 5f1a5bd437ce82336383f89e825c369f21749f15..2c314e7b55b9ab7983f565b2ac2bbb08ef0770c6 100644 (file)\n--- a/libavcodec/vc1dec.c\n+++ b/libavcodec/vc1dec.c\n@@ -788,6 +788,7 @@ static av_cold void vc1_decode_reset(AVCodecContext *avctx)\n     for (i = 0; i < 4; i++)\n         av_freep(&v->sr_rows[i >> 1][i & 1]);\n     ff_mpv_common_end(&v->s);\n+    memset(v->s.block_index, 0, sizeof(v->s.block_index));\n     av_freep(&v->mv_type_mb_plane);\n     av_freep(&v->direct_mb_plane);\n     av_freep(&v->forward_mb_plane);\n\n",
    "patch_modified_files": [
        "libavcodec/vc1dec.c"
    ],
    "sanitizer": "memory",
    "engine": "libfuzzer",
    "target": "ffmpeg_AV_CODEC_ID_VC1_fuzzer"
}
