diff options
author | Michael Chinen <mchinen@gmail.com> | 2010-12-12 00:52:54 +0000 |
---|---|---|
committer | Justin Ruggles <justin.ruggles@gmail.com> | 2010-12-12 00:52:54 +0000 |
commit | 97f7fe687ae40f677aa48dc3be96e4842471f38e (patch) | |
tree | 5dc46507b091c0963fd8f8fcbf75f67e29516ba7 /libavcodec/flac_parser.c | |
parent | 4172951ba7e5e8450d2b081fa9516454fdfa1329 (diff) | |
download | ffmpeg-97f7fe687ae40f677aa48dc3be96e4842471f38e.tar.gz |
Make FLAC parser return frames when it has the required amount
(without buffering extra input).
Patch by Michael Chinen [mchinen at gmail]
Originally committed as revision 25932 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/flac_parser.c')
-rw-r--r-- | libavcodec/flac_parser.c | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/libavcodec/flac_parser.c b/libavcodec/flac_parser.c index 5aeb923406..962b37e03e 100644 --- a/libavcodec/flac_parser.c +++ b/libavcodec/flac_parser.c @@ -75,6 +75,7 @@ typedef struct FLACParseContext { FLACHeaderMarker *best_header; /**< highest scoring header within buffer */ int nb_headers_found; /**< number of headers found in the last flac_parse() call */ + int nb_headers_buffered; /**< number of headers that are buffered */ int best_header_valid; /**< flag set when the parser returns junk; if set return best_header next time */ AVFifoBuffer *fifo_buf; /**< buffer to store all data until headers @@ -504,6 +505,7 @@ static int flac_parse(AVCodecParserContext *s, AVCodecContext *avctx, temp = curr->next; av_freep(&curr->link_penalty); av_free(curr); + fpc->nb_headers_buffered--; } /* Release returned data from ring buffer. */ av_fifo_drain(fpc->fifo_buf, best_child->offset); @@ -512,8 +514,13 @@ static int flac_parse(AVCodecParserContext *s, AVCodecContext *avctx, for (curr = best_child->next; curr; curr = curr->next) curr->offset -= best_child->offset; + fpc->nb_headers_buffered--; best_child->offset = 0; fpc->headers = best_child; + if (fpc->nb_headers_buffered >= FLAC_MIN_HEADERS) { + fpc->best_header = best_child; + return get_best_header(fpc, poutbuf, poutbuf_size); + } fpc->best_header = NULL; } else if (fpc->best_header) { /* No end frame no need to delete the buffer; probably eof */ @@ -562,8 +569,15 @@ static int flac_parse(AVCodecParserContext *s, AVCodecContext *avctx, start_offset = FFMAX(0, start_offset); nb_headers = find_new_headers(fpc, start_offset); + if (nb_headers < 0) { + av_log(avctx, AV_LOG_ERROR, + "find_new_headers couldn't allocate FLAC header\n"); + goto handle_error; + } + + fpc->nb_headers_buffered = nb_headers; /* Wait till FLAC_MIN_HEADERS to output a valid frame. */ - if (!fpc->end_padded && nb_headers < FLAC_MIN_HEADERS) + if (!fpc->end_padded && fpc->nb_headers_buffered < FLAC_MIN_HEADERS) goto handle_error; /* If headers found, update the scores since we have longer chains. */ |