mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-23 12:43:46 +02:00
avcodec/vqcdec: Check for end of input in decode_vectors()
Fixes: Timeout Fixes: 52695/clusterfuzz-testcase-minimized-ffmpeg_AV_CODEC_ID_VQC_fuzzer-4882310386548736 Found-by: continuous fuzzing process https://github.com/google/oss-fuzz/tree/master/projects/ffmpeg Reviewed-by: Peter Ross <pross@xvid.org> Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
This commit is contained in:
parent
6634b6ae5f
commit
0871cb9499
@ -137,7 +137,7 @@ static void seed_codebooks(VqcContext * s, const int * seed)
|
||||
}
|
||||
}
|
||||
|
||||
static void decode_vectors(VqcContext * s, const uint8_t * buf, int size, int width, int height)
|
||||
static int decode_vectors(VqcContext * s, const uint8_t * buf, int size, int width, int height)
|
||||
{
|
||||
GetBitContext gb;
|
||||
uint8_t * vectors = s->vectors;
|
||||
@ -155,9 +155,11 @@ static void decode_vectors(VqcContext * s, const uint8_t * buf, int size, int wi
|
||||
*dst++ = get_bits(&gb, 8);
|
||||
|
||||
while (show_bits(&gb, 2) != 2) {
|
||||
|
||||
if (dst >= vectors_end - 1)
|
||||
return;
|
||||
return 0;
|
||||
|
||||
if (get_bits_left(&gb) < 4)
|
||||
return AVERROR_INVALIDDATA;
|
||||
|
||||
if (!show_bits(&gb, 4)) {
|
||||
*dst++ = 0;
|
||||
@ -182,6 +184,8 @@ static void decode_vectors(VqcContext * s, const uint8_t * buf, int size, int wi
|
||||
skip_bits(&gb, 2);
|
||||
vectors += 32;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void load_coeffs(VqcContext * s, const uint8_t * v, int width, int coeff_width)
|
||||
@ -392,7 +396,9 @@ static int vqc_decode_frame(AVCodecContext *avctx, AVFrame * rframe,
|
||||
avpriv_request_sample(avctx, "gamma=0x%x, contrast=0x%x\n", gamma, contrast);
|
||||
|
||||
seed_codebooks(s, seed);
|
||||
decode_vectors(s, buf + 7, avpkt->size - 7, avctx->width, avctx->height);
|
||||
ret = decode_vectors(s, buf + 7, avpkt->size - 7, avctx->width, avctx->height);
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
decode_frame(s, avctx->width, avctx->height);
|
||||
|
||||
if ((ret = av_frame_ref(rframe, s->frame)) < 0)
|
||||
|
Loading…
Reference in New Issue
Block a user