From: Andreas Cadhalpun Date: Sun, 15 Nov 2015 09:33:40 +0000 (+0100) Subject: hqx: correct type and size check of info_offset X-Git-Url: https://git.sesse.net/?a=commitdiff_plain;h=1ed7fcd42af956979abf4e32cd3c9ee17622bbcb;p=ffmpeg hqx: correct type and size check of info_offset It is used as size argument of ff_canopus_parse_info_tag, which uses it as size argument to bytestream2_init, which only supports sizes up to INT_MAX. Changing it's type to unsigned simplifies the check. Reviewed-by: Vittorio Giovara Signed-off-by: Andreas Cadhalpun --- diff --git a/libavcodec/hqx.c b/libavcodec/hqx.c index 8060c7a31c0..138d9604118 100644 --- a/libavcodec/hqx.c +++ b/libavcodec/hqx.c @@ -417,8 +417,8 @@ static int hqx_decode_frame(AVCodecContext *avctx, void *data, info_tag = AV_RL32(src); if (info_tag == MKTAG('I', 'N', 'F', 'O')) { - int info_offset = AV_RL32(src + 4); - if (info_offset > UINT32_MAX - 8 || info_offset + 8 > avpkt->size) { + unsigned info_offset = AV_RL32(src + 4); + if (info_offset > INT_MAX || info_offset + 8 > avpkt->size) { av_log(avctx, AV_LOG_ERROR, "Invalid INFO header offset: 0x%08"PRIX32" is too large.\n", info_offset);