[FFmpeg-devel] [PATCH 3/7] hwcontext_vaapi: Pass correct read/write flags when exporting surfaces

Rostislav Pehlivanov atomnuker at gmail.com
Mon Mar 12 02:03:41 EET 2018


On 11 March 2018 at 22:41, Mark Thompson <sw at jkqxz.net> wrote:

> ---
>  libavutil/hwcontext_vaapi.c | 11 ++++++++---
>  1 file changed, 8 insertions(+), 3 deletions(-)
>
> diff --git a/libavutil/hwcontext_vaapi.c b/libavutil/hwcontext_vaapi.c
> index 15f1c4d1c0..8e4bef9f1b 100644
> --- a/libavutil/hwcontext_vaapi.c
> +++ b/libavutil/hwcontext_vaapi.c
> @@ -1094,15 +1094,20 @@ static int vaapi_map_to_drm_esh(AVHWFramesContext
> *hwfc, AVFrame *dst,
>      VAStatus vas;
>      VADRMPRIMESurfaceDescriptor va_desc;
>      AVDRMFrameDescriptor *drm_desc = NULL;
> +    uint32_t export_flags;
>      int err, i, j;
>
>      surface_id = (VASurfaceID)(uintptr_t)src->data[3];
>
> +    export_flags = VA_EXPORT_SURFACE_SEPARATE_LAYERS;
> +    if (flags & AV_HWFRAME_MAP_READ)
> +        export_flags |= VA_EXPORT_SURFACE_READ_ONLY;
> +    if (flags & AV_HWFRAME_MAP_WRITE)
> +        export_flags |= VA_EXPORT_SURFACE_WRITE_ONLY;
> +
>      vas = vaExportSurfaceHandle(hwctx->display, surface_id,
>                                  VA_SURFACE_ATTRIB_MEM_TYPE_DRM_PRIME_2,
> -                                VA_EXPORT_SURFACE_READ_ONLY |
> -                                VA_EXPORT_SURFACE_SEPARATE_LAYERS,
> -                                &va_desc);
> +                                export_flags, &va_desc);
>      if (vas != VA_STATUS_SUCCESS) {
>          if (vas == VA_STATUS_ERROR_UNIMPLEMENTED)
>              return AVERROR(ENOSYS);
> --
> 2.16.1
>
> _______________________________________________
> ffmpeg-devel mailing list
> ffmpeg-devel at ffmpeg.org
> http://ffmpeg.org/mailman/listinfo/ffmpeg-devel
>

LGTM


More information about the ffmpeg-devel mailing list