{
    "id": "377748135",
    "link": "https://issues.oss-fuzz.com/issues/377748135",
    "title": "UndefinedBehaviorSanitizer: Index-out-of-bounds in read_sbr_invf",
    "parent_of_fix_commit": "0b67c83b2eadf6350587ae7c4a63a8f9bba67cae",
    "crashes": [
        {
            "kernel-source-commit": "0b67c83b2eadf6350587ae7c4a63a8f9bba67cae",
            "crash-report-data": "libavcodec/aacsbr_template.c:833:9: runtime error: index 5 out of bounds for type 'uint8_t[5]' (aka 'unsigned char[5]')\n    #0 0x55f651b63404 in read_sbr_invf libavcodec/aacsbr_template.c:833:37\n    #1 0x55f651b5ee57 in ff_aac_sbr_decode_usac_data libavcodec/aacsbr_template.c:1280:9\n    #2 0x55f651b4f0b8 in decode_usac_core_coder libavcodec/aac/aacdec_usac.c:1478:15\n    #3 0x55f651b4b881 in ff_aac_usac_decode_frame libavcodec/aac/aacdec_usac.c:1722:19\n    #4 0x55f651b2fcf1 in aac_decode_frame_int libavcodec/aac/aacdec.c:2414:15\n    #5 0x55f651b27b70 in latm_decode_frame libavcodec/aac/aacdec_latm.h:309:15\n    #6 0x55f651b89ce2 in decode_simple_internal libavcodec/decode.c:429:20\n    #7 0x55f651b89ce2 in decode_simple_receive_frame libavcodec/decode.c:600:15\n    #8 0x55f651b89ce2 in decode_receive_frame_internal libavcodec/decode.c:631:15\n    #9 0x55f651b89929 in avcodec_send_packet libavcodec/decode.c:721:15\n    #10 0x55f651b1f01b in LLVMFuzzerTestOneInput tools/target_dec_fuzzer.c:533:25\n    #11 0x55f651a7fc60 in fuzzer::Fuzzer::ExecuteCallback(unsigned char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:614:13\n    #12 0x55f651a6aed5 in fuzzer::RunOneTest(fuzzer::Fuzzer*, char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:327:6\n    #13 0x55f651a7096f in fuzzer::FuzzerDriver(int*, char***, int (*)(unsigned char const*, unsigned long)) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:862:9\n    #14 0x55f651a9bc12 in main /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerMain.cpp:20:10\n    #15 0x7f33d3e88082 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24082) (BuildId: 0323ab4806bee6f846d9ad4bccfc29afdca49a58)\n    #16 0x55f651a630bd in _start (/out/ffmpeg_AV_CODEC_ID_AAC_LATM_fuzzer+0x4640bd)\n\nDEDUP_TOKEN: read_sbr_invf--ff_aac_sbr_decode_usac_data--decode_usac_core_coder\nSUMMARY: UndefinedBehaviorSanitizer: undefined-behavior libavcodec/aacsbr_template.c:833:9"
        }
    ],
    "patch": "diff --git a/libavcodec/aacsbr_template.c b/libavcodec/aacsbr_template.c\nindex 436b549fe70fdb0f78c94412586baa87d595b9cd..9fae44d9a5cbd9dc743255d705ded673db821729 100644 (file)\n--- a/libavcodec/aacsbr_template.c\n+++ b/libavcodec/aacsbr_template.c\n@@ -599,6 +599,7 @@ static int sbr_make_f_derived(AACDecContext *ac, SpectralBandReplication *sbr)\n \n     if (sbr->n_q > 5) {\n         av_log(ac->avctx, AV_LOG_ERROR, \"Too many noise floor scale factors: %d\\n\", sbr->n_q);\n+        sbr->n_q = 1;\n         return -1;\n     }\n \n\n",
    "patch_modified_files": [
        "libavcodec/aacsbr_template.c"
    ],
    "sanitizer": "undefined",
    "engine": "libfuzzer",
    "target": "ffmpeg_AV_CODEC_ID_AAC_LATM_fuzzer"
}
