Mercurial > libavcodec.hg
changeset 6932:ea72fccbfc3b libavcodec
in TRUNCATED mode, use residual fragments in ParseContext
for decoding the very last frame.
author | skal |
---|---|
date | Thu, 29 May 2008 20:09:45 +0000 |
parents | 8decc970f9c8 |
children | 74f920fb6c01 |
files | h264.c |
diffstat | 1 files changed, 9 insertions(+), 8 deletions(-) [+] |
line wrap: on
line diff
--- a/h264.c Thu May 29 11:04:42 2008 +0000 +++ b/h264.c Thu May 29 20:09:45 2008 +0000 @@ -7656,6 +7656,15 @@ s->flags= avctx->flags; s->flags2= avctx->flags2; + if(s->flags&CODEC_FLAG_TRUNCATED){ + const int next= ff_h264_find_frame_end(h, buf, buf_size); + assert((buf_size > 0) || (next == END_NOT_FOUND)); + + if( ff_combine_frame(&s->parse_context, next, &buf, &buf_size) < 0 ) + return buf_size; +//printf("next:%d buf_size:%d last_index:%d\n", next, buf_size, s->parse_context.last_index); + } + /* no supplementary picture */ if (buf_size == 0) { Picture *out; @@ -7681,14 +7690,6 @@ return 0; } - if(s->flags&CODEC_FLAG_TRUNCATED){ - int next= ff_h264_find_frame_end(h, buf, buf_size); - - if( ff_combine_frame(&s->parse_context, next, (const uint8_t **)&buf, &buf_size) < 0 ) - return buf_size; -//printf("next:%d buf_size:%d last_index:%d\n", next, buf_size, s->parse_context.last_index); - } - if(h->is_avc && !h->got_avcC) { int i, cnt, nalsize; unsigned char *p = avctx->extradata;