From: Michael Niedermayer Date: Mon, 7 Jan 2019 01:44:50 +0000 (+0100) Subject: avcodec/qpeg: Optimize long runs in qpeg_decode_intra() not spanning a full row X-Git-Url: https://git.sesse.net/?a=commitdiff_plain;h=038d291b70bffa550cde552f8325e1b9f71f0646;p=ffmpeg avcodec/qpeg: Optimize long runs in qpeg_decode_intra() not spanning a full row Fixes: Timeout Fixes: 11354/clusterfuzz-testcase-minimized-ffmpeg_AV_CODEC_ID_QPEG_fuzzer-5766275943366656 Before: Executed clusterfuzz-testcase-minimized-ffmpeg_AV_CODEC_ID_QPEG_fuzzer-5766275943366656 in 9470 ms After : Executed clusterfuzz-testcase-minimized-ffmpeg_AV_CODEC_ID_QPEG_fuzzer-5766275943366656 in 134 ms Found-by: continuous fuzzing process https://github.com/google/oss-fuzz/tree/master/projects/ffmpeg Reviewed-by: Paul B Mahol Signed-off-by: Michael Niedermayer --- diff --git a/libavcodec/qpeg.c b/libavcodec/qpeg.c index cb452621e7d..654fd998d6a 100644 --- a/libavcodec/qpeg.c +++ b/libavcodec/qpeg.c @@ -80,7 +80,10 @@ static void qpeg_decode_intra(QpegContext *qctx, uint8_t *dst, p = bytestream2_get_byte(&qctx->buffer); for(i = 0; i < run; i++) { - dst[filled++] = p; + int step = FFMIN(run - i, width - filled); + memset(dst+filled, p, step); + filled += step; + i += step - 1; if (filled >= width) { filled = 0; dst -= stride;