Commit 5b98ea1b authored by Michael Niedermayer's avatar Michael Niedermayer

vb: Add some checks on input buffer related values.

Fixes crash with INTRO_FAIL.VB
Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parent 4557d7d0
...@@ -221,10 +221,14 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size, AVPac ...@@ -221,10 +221,14 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size, AVPac
offset = i + j * avctx->width; offset = i + j * avctx->width;
rest -= 4; rest -= 4;
} }
if(rest < 0){
av_log(avctx, AV_LOG_ERROR, "not enough data\n");
return -1;
}
if(flags & VB_HAS_VIDEO){ if(flags & VB_HAS_VIDEO){
size = bytestream_get_le32(&c->stream); size = bytestream_get_le32(&c->stream);
if(size > rest){ if(size > rest || size<4){
av_log(avctx, AV_LOG_ERROR, "Frame size is too big\n"); av_log(avctx, AV_LOG_ERROR, "Frame size invalid\n");
return -1; return -1;
} }
vb_decode_framedata(c, c->stream, size, offset); vb_decode_framedata(c, c->stream, size, offset);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment