You've already forked FFmpeg
mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-08-10 06:10:52 +02:00
h264_slice: Wait for refs to be available before we use them in error concealment
This could happen when there was a frame number gap and frame threading was used. Debugging-by: Ronald S. Bultje <rsbultje@gmail.com> Debugging-by: Justin Ruggles <justin.ruggles@gmail.com> Signed-off-by: Derek Buitenhuis <derek.buitenhuis@gmail.com> CC:libav-stable@libav.org Signed-off-by: Anton Khirnov <anton@khirnov.net>
This commit is contained in:
committed by
Anton Khirnov
parent
86157e6db2
commit
5c7f2cf81d
@@ -1404,6 +1404,9 @@ static int h264_field_start(H264Context *h, const H264SliceContext *sl,
|
|||||||
h->short_ref[0]->f->width == prev->f->width &&
|
h->short_ref[0]->f->width == prev->f->width &&
|
||||||
h->short_ref[0]->f->height == prev->f->height &&
|
h->short_ref[0]->f->height == prev->f->height &&
|
||||||
h->short_ref[0]->f->format == prev->f->format) {
|
h->short_ref[0]->f->format == prev->f->format) {
|
||||||
|
ff_thread_await_progress(&prev->tf, INT_MAX, 0);
|
||||||
|
if (prev->field_picture)
|
||||||
|
ff_thread_await_progress(&prev->tf, INT_MAX, 1);
|
||||||
av_image_copy(h->short_ref[0]->f->data,
|
av_image_copy(h->short_ref[0]->f->data,
|
||||||
h->short_ref[0]->f->linesize,
|
h->short_ref[0]->f->linesize,
|
||||||
(const uint8_t **)prev->f->data,
|
(const uint8_t **)prev->f->data,
|
||||||
|
Reference in New Issue
Block a user