[FFmpeg-cvslog] vp9: fix show-existing-frames for multi-threading.
Ronald S. Bultje
git at videolan.org
Thu Apr 30 23:32:26 CEST 2015
ffmpeg | branch: master | Ronald S. Bultje <rsbultje at gmail.com> | Thu Apr 30 22:03:10 2015 +0200| [5935513c0ed1563a654b2e40d053f824bae93e6b] | committer: Michael Niedermayer
vp9: fix show-existing-frames for multi-threading.
This also fixes intra-only MT failures (it was the same bug), see trac
4526 and 4527.
Tested-by: James Almer <jamrial at gmail.com>
Reviewed-by: James Almer <jamrial at gmail.com>
Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=5935513c0ed1563a654b2e40d053f824bae93e6b
---
libavcodec/vp9.c | 7 +++++++
1 file changed, 7 insertions(+)
diff --git a/libavcodec/vp9.c b/libavcodec/vp9.c
index 1310798..84e2220 100644
--- a/libavcodec/vp9.c
+++ b/libavcodec/vp9.c
@@ -3767,6 +3767,13 @@ static int vp9_decode_frame(AVCodecContext *ctx, void *frame,
return res;
((AVFrame *)frame)->pkt_pts = pkt->pts;
((AVFrame *)frame)->pkt_dts = pkt->dts;
+ for (i = 0; i < 8; i++) {
+ if (s->next_refs[i].f->data[0])
+ ff_thread_release_buffer(ctx, &s->next_refs[i]);
+ if (s->refs[i].f->data[0] &&
+ (res = ff_thread_ref_frame(&s->next_refs[i], &s->refs[i])) < 0)
+ return res;
+ }
*got_frame = 1;
return pkt->size;
}
More information about the ffmpeg-cvslog
mailing list