X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;ds=sidebyside;f=libavformat%2Foggparsespeex.c;h=27fc99247de3be20eb4d4a9b429446a1349d4d6d;hb=d2119f624d392f53f80c3d36ffaadca23aef8a10;hp=2b4915087821d33794d5bc59a079620bd4f76d98;hpb=cca4fd477851c3ab3b4ee7da525d5eb81bbe8de1;p=ffmpeg diff --git a/libavformat/oggparsespeex.c b/libavformat/oggparsespeex.c index 2b491508782..27fc99247de 100644 --- a/libavformat/oggparsespeex.c +++ b/libavformat/oggparsespeex.c @@ -82,6 +82,13 @@ static int speex_header(AVFormatContext *s, int idx) { spxp->packet_size = AV_RL32(p + 56); frames_per_packet = AV_RL32(p + 64); + if (spxp->packet_size < 0 || + frames_per_packet < 0 || + spxp->packet_size * (int64_t)frames_per_packet > INT32_MAX / 256) { + av_log(s, AV_LOG_ERROR, "invalid packet_size, frames_per_packet %d %d\n", spxp->packet_size, frames_per_packet); + spxp->packet_size = 0; + return AVERROR_INVALIDDATA; + } if (frames_per_packet) spxp->packet_size *= frames_per_packet;