[SCM] libav/experimental: Fixed h264 long term support with dxva2 AVHWAccel.
siretart at users.alioth.debian.org
siretart at users.alioth.debian.org
Sun Jun 30 17:07:11 UTC 2013
The following commit has been merged in the experimental branch:
commit efb816ef64fc2d65fa75254d504f39ab00422fa4
Author: Laurent Aimar <fenrir at videolan.org>
Date: Fri May 14 23:08:23 2010 +0000
Fixed h264 long term support with dxva2 AVHWAccel.
Based on a commit for vaapi(r22869).
Originally committed as revision 23140 to svn://svn.ffmpeg.org/ffmpeg/trunk
diff --git a/libavcodec/dxva2_h264.c b/libavcodec/dxva2_h264.c
index 22c76df..b0b126a 100644
--- a/libavcodec/dxva2_h264.c
+++ b/libavcodec/dxva2_h264.c
@@ -46,7 +46,7 @@ static void fill_picture_parameters(struct dxva_context *ctx, const H264Context
{
const MpegEncContext *s = &h->s;
const Picture *current_picture = s->current_picture_ptr;
- int i;
+ int i, j;
memset(pp, 0, sizeof(*pp));
/* Configure current picture */
@@ -56,16 +56,16 @@ static void fill_picture_parameters(struct dxva_context *ctx, const H264Context
/* Configure the set of references */
pp->UsedForReferenceFlags = 0;
pp->NonExistingFrameFlags = 0;
- for (i = 0; i < FF_ARRAY_ELEMS(pp->RefFrameList); i++) {
- if (i < h->short_ref_count + h->long_ref_count) {
+ for (i = 0, j = 0; i < FF_ARRAY_ELEMS(pp->RefFrameList); i++) {
const Picture *r;
- if (i < h->short_ref_count) {
- r = h->short_ref[i];
- assert(!r->long_ref);
+ if (j < h->short_ref_count) {
+ r = h->short_ref[j++];
} else {
- r = h->long_ref[i - h->short_ref_count];
- assert(r->long_ref);
+ r = NULL;
+ while (!r && j < h->short_ref_count + 16)
+ r = h->long_ref[j++ - h->short_ref_count];
}
+ if (r) {
fill_picture_entry(&pp->RefFrameList[i],
ff_dxva2_get_surface_index(ctx, r),
r->long_ref != 0);
--
Libav/FFmpeg packaging
More information about the pkg-multimedia-commits
mailing list