mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-11-21 10:55:51 +02:00
threads: fix old frames returned after avcodec_flush_buffers()
Calling avcodec_flush_buffers() and then avcodec_decode_video2() with a 0-sized packet (to get remaining buffered frames) could incorrectly return an old frame from before the avcodec_flush_buffers() call. Add a loop in ff_thread_flush() to zero the got_frame field of each thread to ensure the old frames will not be returned. Signed-off-by: Ronald S. Bultje <rsbultje@gmail.com>
This commit is contained in:
parent
7b60799aa8
commit
05b9a89ed7
@ -884,6 +884,9 @@ void ff_thread_flush(AVCodecContext *avctx)
|
||||
fctx->next_decoding = fctx->next_finished = 0;
|
||||
fctx->delaying = 1;
|
||||
fctx->prev_thread = NULL;
|
||||
// Make sure decode flush calls with size=0 won't return old frames
|
||||
for (int i = 0; i < avctx->thread_count; i++)
|
||||
fctx->threads[i].got_frame = 0;
|
||||
}
|
||||
|
||||
static int *allocate_progress(PerThreadContext *p)
|
||||
|
Loading…
Reference in New Issue
Block a user