Commit 266c1d90 authored by Michael Niedermayer's avatar Michael Niedermayer

Do not discard mp3 frames in the parser after a broken frame.

Fixes issue1044.
This may cause regressions with broken streams, if you find any, please report!

Originally committed as revision 18741 to svn://svn.ffmpeg.org/ffmpeg/trunk
parent 3cb08886
...@@ -223,10 +223,8 @@ static int mpegaudio_parse(AVCodecParserContext *s1, ...@@ -223,10 +223,8 @@ static int mpegaudio_parse(AVCodecParserContext *s1,
if(s->frame_size > 0 && buf_ptr - buf == s->inbuf_ptr - s->inbuf if(s->frame_size > 0 && buf_ptr - buf == s->inbuf_ptr - s->inbuf
&& buf_size + buf_ptr - buf >= s->frame_size){ && buf_size + buf_ptr - buf >= s->frame_size){
if(s->header_count > 0){
*poutbuf = buf; *poutbuf = buf;
*poutbuf_size = s->frame_size; *poutbuf_size = s->frame_size;
}
buf_ptr = buf + s->frame_size; buf_ptr = buf + s->frame_size;
s->inbuf_ptr = s->inbuf; s->inbuf_ptr = s->inbuf;
s->frame_size = 0; s->frame_size = 0;
...@@ -236,10 +234,8 @@ static int mpegaudio_parse(AVCodecParserContext *s1, ...@@ -236,10 +234,8 @@ static int mpegaudio_parse(AVCodecParserContext *s1,
// next_data: // next_data:
if (s->frame_size > 0 && if (s->frame_size > 0 &&
(s->inbuf_ptr - s->inbuf) >= s->frame_size) { (s->inbuf_ptr - s->inbuf) >= s->frame_size) {
if(s->header_count > 0){
*poutbuf = s->inbuf; *poutbuf = s->inbuf;
*poutbuf_size = s->inbuf_ptr - s->inbuf; *poutbuf_size = s->inbuf_ptr - s->inbuf;
}
s->inbuf_ptr = s->inbuf; s->inbuf_ptr = s->inbuf;
s->frame_size = 0; s->frame_size = 0;
break; break;
......
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