mirror of
https://github.com/librempeg/librempeg
synced 2024-11-23 19:58:59 +00:00
Return an error when the parsed mpc chunk size is negative, otherwise we
might end up in an endless loop where the same chunk is parsed over and over. Fixes a hang near the end for http://samples.mplayerhq.hu/A-codecs/musepack/sv8/sv8-tags.mpc Originally committed as revision 20099 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
58f873dded
commit
5dd76bd741
@ -250,6 +250,8 @@ static int mpc8_read_packet(AVFormatContext *s, AVPacket *pkt)
|
||||
while(!url_feof(s->pb)){
|
||||
pos = url_ftell(s->pb);
|
||||
mpc8_get_chunk_header(s->pb, &tag, &size);
|
||||
if (size < 0)
|
||||
return -1;
|
||||
if(tag == TAG_AUDIOPACKET){
|
||||
if(av_get_packet(s->pb, pkt, size) < 0)
|
||||
return AVERROR(ENOMEM);
|
||||
|
Loading…
Reference in New Issue
Block a user