[FFmpeg-devel] [PATCH] lavu/hwcontext_qsv: Derive bind flag from frame type if no valid surface
Tong Wu
wutong1208 at outlook.com
Mon Jul 29 18:27:10 EEST 2024
>-----Original Message-----
>From: ffmpeg-devel <ffmpeg-devel-bounces at ffmpeg.org> On Behalf Of
>fei.w.wang-at-intel.com at ffmpeg.org
>Sent: 2024年7月23日 9:27
>To: ffmpeg-devel at ffmpeg.org
>Cc: fei.w.wang at intel.com
>Subject: [FFmpeg-devel] [PATCH] lavu/hwcontext_qsv: Derive bind flag from
>frame type if no valid surface
>
>From: Fei Wang <fei.w.wang at intel.com>
>
>Fix cmd:
>ffmpeg.exe -init_hw_device d3d11va=d3d -init_hw_device qsv=qsv at d3d \
>-filter_hw_device d3d -hwaccel qsv -hwaccel_output_format qsv \
>-i in.h264 -vf "hwmap,format=d3d11,hwdownload,format=nv12" -y out.yuv
>
>Signed-off-by: Fei Wang <fei.w.wang at intel.com>
>---
> libavutil/hwcontext_qsv.c | 7 +++++--
> 1 file changed, 5 insertions(+), 2 deletions(-)
>
>diff --git a/libavutil/hwcontext_qsv.c b/libavutil/hwcontext_qsv.c index
>7cec347478..09156275ec 100644
>--- a/libavutil/hwcontext_qsv.c
>+++ b/libavutil/hwcontext_qsv.c
>@@ -1549,8 +1549,11 @@ static int
>qsv_frames_derive_from(AVHWFramesContext *dst_ctx,
> dst_hwctx->texture_infos[i].texture = (ID3D11Texture2D*)pair->first;
> dst_hwctx->texture_infos[i].index = pair->second ==
>(mfxMemId)MFX_INFINITE ? (intptr_t)0 : (intptr_t)pair->second;
> }
>- ID3D11Texture2D_GetDesc(dst_hwctx->texture_infos[0].texture,
>&texDesc);
>- dst_hwctx->BindFlags = texDesc.BindFlags;
>+ if (src_hwctx->nb_surfaces) {
>+ ID3D11Texture2D_GetDesc(dst_hwctx->texture_infos[0].texture,
>&texDesc);
>+ dst_hwctx->BindFlags = texDesc.BindFlags;
>+ } else
>+ dst_hwctx->BindFlags =
>+ qsv_get_d3d11va_bind_flags(src_hwctx->frame_type);
> }
> break;
> #endif
>--
>2.34.1
>
Tested. LGTM. Thanks.
More information about the ffmpeg-devel
mailing list