Commit 3bb258cd authored by bellard's avatar bellard

added End Of File handling to return last picture for MPEG1/2/4


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@2614 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent a9ac638f
...@@ -63,12 +63,22 @@ AVCodecParserContext *av_parser_init(int codec_id) ...@@ -63,12 +63,22 @@ AVCodecParserContext *av_parser_init(int codec_id)
return s; return s;
} }
/* NOTE: buf_size == 0 is used to signal EOF so that the last frame
can be returned if necessary */
int av_parser_parse(AVCodecParserContext *s, int av_parser_parse(AVCodecParserContext *s,
AVCodecContext *avctx, AVCodecContext *avctx,
uint8_t **poutbuf, int *poutbuf_size, uint8_t **poutbuf, int *poutbuf_size,
const uint8_t *buf, int buf_size) const uint8_t *buf, int buf_size)
{ {
int index; int index;
uint8_t dummy_buf[FF_INPUT_BUFFER_PADDING_SIZE];
if (buf_size == 0) {
/* padding is always necessary even if EOF, so we add it here */
memset(dummy_buf, 0, sizeof(dummy_buf));
buf = dummy_buf;
}
/* WARNING: the returned index can be negative */ /* WARNING: the returned index can be negative */
index = s->parser->parser_parse(s, avctx, poutbuf, poutbuf_size, buf, buf_size); index = s->parser->parser_parse(s, avctx, poutbuf, poutbuf_size, buf, buf_size);
/* update the file pointer */ /* update the file pointer */
...@@ -201,6 +211,9 @@ static int mpeg1_find_frame_end(ParseContext1 *pc, const uint8_t *buf, int buf_s ...@@ -201,6 +211,9 @@ static int mpeg1_find_frame_end(ParseContext1 *pc, const uint8_t *buf, int buf_s
} }
if(pc->frame_start_found){ if(pc->frame_start_found){
/* EOF considered as end of frame */
if (buf_size == 0)
return 0;
for(; i<buf_size; i++){ for(; i<buf_size; i++){
state= (state<<8) | buf[i]; state= (state<<8) | buf[i];
if((state&0xFFFFFF00) == 0x100){ if((state&0xFFFFFF00) == 0x100){
...@@ -418,14 +431,17 @@ static int mpeg4_find_frame_end(ParseContext1 *pc, ...@@ -418,14 +431,17 @@ static int mpeg4_find_frame_end(ParseContext1 *pc,
} }
if(vop_found){ if(vop_found){
for(; i<buf_size; i++){ /* EOF considered as end of frame */
state= (state<<8) | buf[i]; if (buf_size == 0)
if((state&0xFFFFFF00) == 0x100){ return 0;
pc->frame_start_found=0; for(; i<buf_size; i++){
pc->state=-1; state= (state<<8) | buf[i];
return i-3; if((state&0xFFFFFF00) == 0x100){
pc->frame_start_found=0;
pc->state=-1;
return i-3;
}
} }
}
} }
pc->frame_start_found= vop_found; pc->frame_start_found= vop_found;
pc->state= state; pc->state= state;
......
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