From: Leo Liu Date: Tue, 29 Aug 2017 03:07:33 +0000 (-0400) Subject: st/va: move YUV content to deinterlaced buffer when reallocated for encoder X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=15d4d44d9b2467484b95f71d76224b7de2da5e40;p=mesa.git st/va: move YUV content to deinterlaced buffer when reallocated for encoder v2: use deinterlace common function v3: make sure deinterlace only Signed-off-by: Leo Liu Reviewed-by: Christian König --- diff --git a/src/gallium/state_trackers/va/picture.c b/src/gallium/state_trackers/va/picture.c index ee099fad6ee..19df52cb83e 100644 --- a/src/gallium/state_trackers/va/picture.c +++ b/src/gallium/state_trackers/va/picture.c @@ -660,13 +660,22 @@ vlVaEndPicture(VADriverContextP ctx, VAContextID context_id) } if (realloc) { - surf->buffer->destroy(surf->buffer); + struct pipe_video_buffer *old_buf = surf->buffer; if (vlVaHandleSurfaceAllocate(ctx, surf, &surf->templat) != VA_STATUS_SUCCESS) { mtx_unlock(&drv->mutex); return VA_STATUS_ERROR_ALLOCATION_FAILED; } + if (context->decoder->entrypoint == PIPE_VIDEO_ENTRYPOINT_ENCODE) { + if (old_buf->interlaced) + vl_compositor_yuv_deint(&drv->cstate, &drv->compositor, old_buf, surf->buffer); + else + /* Can't convert from progressive to interlaced yet */ + return VA_STATUS_ERROR_INVALID_SURFACE; + } + + old_buf->destroy(old_buf); context->target = surf->buffer; }