[FFmpeg-devel] [PATCH] Support PARSER_FLAG_COMPLETE_FRAMES for h261 and h263 parsers.

Reimar Döffinger Reimar.Doeffinger at gmx.de
Sun Apr 24 19:20:01 CEST 2011


---
 libavcodec/h261_parser.c |    4 ++++
 libavcodec/h263_parser.c |    4 ++++
 2 files changed, 8 insertions(+), 0 deletions(-)

diff --git a/libavcodec/h261_parser.c b/libavcodec/h261_parser.c
index defc1cb..4d20afe 100644
--- a/libavcodec/h261_parser.c
+++ b/libavcodec/h261_parser.c
@@ -70,12 +70,16 @@ static int h261_parse(AVCodecParserContext *s,
     ParseContext *pc = s->priv_data;
     int next;
 
+    if (s->flags & PARSER_FLAG_COMPLETE_FRAMES) {
+        next = buf_size;
+    } else {
     next= h261_find_frame_end(pc,avctx, buf, buf_size);
     if (ff_combine_frame(pc, next, &buf, &buf_size) < 0) {
         *poutbuf = NULL;
         *poutbuf_size = 0;
         return buf_size;
     }
+    }
     *poutbuf = buf;
     *poutbuf_size = buf_size;
     return next;
diff --git a/libavcodec/h263_parser.c b/libavcodec/h263_parser.c
index e081983..2a00291 100644
--- a/libavcodec/h263_parser.c
+++ b/libavcodec/h263_parser.c
@@ -70,6 +70,9 @@ static int h263_parse(AVCodecParserContext *s,
     ParseContext *pc = s->priv_data;
     int next;
 
+    if (s->flags & PARSER_FLAG_COMPLETE_FRAMES) {
+        next = buf_size;
+    } else {
     next= ff_h263_find_frame_end(pc, buf, buf_size);
 
     if (ff_combine_frame(pc, next, &buf, &buf_size) < 0) {
@@ -77,6 +80,7 @@ static int h263_parse(AVCodecParserContext *s,
         *poutbuf_size = 0;
         return buf_size;
     }
+    }
 
     *poutbuf = buf;
     *poutbuf_size = buf_size;
-- 
1.7.4.4



More information about the ffmpeg-devel mailing list