{
    "id": "385170375",
    "link": "https://issues.oss-fuzz.com/issues/385170375",
    "title": "AddressSanitizer: heap-buffer-overflow in get_vlc2",
    "parent_of_fix_commit": "2d81eaa37bba66e3f48f2905c5dfeaf815f651e1",
    "crashes": [
        {
            "crash-report-data": "AddressSanitizer: heap-buffer-overflow on address 0x51100000038d at pc 0x55ad863c758a bp 0x7ffccd3b24c0 sp 0x7ffccd3b24b8                                                                               READ of size 4 at 0x51100000038d thread T0\nSCARINESS: 17 (4-byte-read-heap-buffer-overflow)\n    #0 0x55ad863c7589 in get_vlc2 libavcodec/get_bits.h:658:5\n    #1 0x55ad863c7589 in decode_4x4_block libavcodec/rv60dec.c:1522:16\n    #2 0x55ad863b81eb in decode_cu_16x16 libavcodec/rv60dec.c:1618:13\n    #3 0x55ad863b81eb in decode_cu_r libavcodec/rv60dec.c:1902:21\n    #4 0x55ad863b1b71 in decode_slice libavcodec/rv60dec.c:2278:20\n    #5 0x55ad8634f747 in avcodec_default_execute2 libavcodec/avcodec.c:91:17\n    #6 0x55ad863ae060 in rv60_decode_frame libavcodec/rv60dec.c:2363:5\n    #7 0x55ad8635cb5d in decode_simple_internal libavcodec/decode.c:443:16\n    #8 0x55ad8635cb5d in decode_simple_receive_frame libavcodec/decode.c:613:15\n    #9 0x55ad8635cb5d in ff_decode_receive_frame_internal libavcodec/decode.c:649:15\n    #10 0x55ad8635eecd in decode_receive_frame_internal libavcodec/decode.c:666:15                                                                                                                           #11 0x55ad8635ed14 in avcodec_send_packet libavcodec/decode.c:753:15                                                                                                                                     #12 0x55ad8634c90b in LLVMFuzzerTestOneInput tools/target_dec_fuzzer.c:542:25                                                                                                                            #13 0x55ad861fee90 in fuzzer::Fuzzer::ExecuteCallback(unsigned char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:614:13                                                            #14 0x55ad861ea105 in fuzzer::RunOneTest(fuzzer::Fuzzer*, char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:327:6                                                                #15 0x55ad861efb9f in fuzzer::FuzzerDriver(int*, char***, int (*)(unsigned char const*, unsigned long)) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:862:9                                              #16 0x55ad8621ae42 in main /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerMain.cpp:20:10\n    #17 0x7f0e21b45082 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24082) (BuildId: 0323ab4806bee6f846d9ad4bccfc29afdca49a58)\n    #18 0x55ad861e22ed in _start (/out/ffmpeg_AV_CODEC_ID_RV60_fuzzer+0x2972ed)\n\nDEDUP_TOKEN: get_vlc2--decode_4x4_block--decode_cu_16x16\n0x51100000038d is located 0 bytes after 205-byte region [0x5110000002c0,0x51100000038d)\nallocated by thread T0 here:\n    #0 0x55ad8630b04c in realloc /src/llvm-project/compiler-rt/lib/asan/asan_malloc_linux.cpp:82:3\n    #1 0x55ad86922c9f in av_buffer_realloc libavutil/buffer.c:192:25\n    #2 0x55ad8639995b in packet_alloc libavcodec/packet.c:89:11\n    #3 0x55ad8639995b in av_new_packet libavcodec/packet.c:101:15\n    #4 0x55ad8634c3ff in LLVMFuzzerTestOneInput tools/target_dec_fuzzer.c:499:15\n    #5 0x55ad861fee90 in fuzzer::Fuzzer::ExecuteCallback(unsigned char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:614:13\n    #6 0x55ad861ea105 in fuzzer::RunOneTest(fuzzer::Fuzzer*, char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:327:6\n    #7 0x55ad861efb9f in fuzzer::FuzzerDriver(int*, char***, int (*)(unsigned char const*, unsigned long)) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:862:9\n    #8 0x55ad8621ae42 in main /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerMain.cpp:20:10\n    #9 0x7f0e21b45082 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24082) (BuildId: 0323ab4806bee6f846d9ad4bccfc29afdca49a58)\n\nDEDUP_TOKEN: __interceptor_realloc--av_buffer_realloc--packet_alloc\nSUMMARY: AddressSanitizer: heap-buffer-overflow libavcodec/get_bits.h:658:5 in get_vlc2",
            "kernel-source-commit": "2d81eaa37bba66e3f48f2905c5dfeaf815f651e1"
        }
    ],
    "patch": "diff --git a/libavcodec/rv60dec.c b/libavcodec/rv60dec.c\nindex 0c2e03d7370ce0f37eb060cb5ffcf7dfa0b67b72..24981015a942bfdf748a4420f8a79a165e88b75c 100644 (file)\n--- a/libavcodec/rv60dec.c\n+++ b/libavcodec/rv60dec.c\n@@ -2257,7 +2257,7 @@ static int decode_slice(AVCodecContext *avctx, void *tdata, int cu_y, int thread\n     thread.avg_linesize[1] = 32;\n     thread.avg_linesize[2] = 32;\n \n-    if ((ret = init_get_bits8(&gb, s->slice[cu_y].data, s->slice[cu_y].size)) < 0)\n+    if ((ret = init_get_bits8(&gb, s->slice[cu_y].data, s->slice[cu_y].data_size)) < 0)\n         return ret;\n \n     for (int cu_x = 0; cu_x < s->cu_width; cu_x++) {\n",
    "patch_modified_files": [
        "libavcodec/rv60dec.c"
    ],
    "sanitizer": "address",
    "engine": "libfuzzer",
    "target": "ffmpeg_AV_CODEC_ID_RV60_fuzzer"
}
