[FFmpeg-devel] [PATCH] libavcodec/qsvenc: add more ChromaFormat support for mjpeg-qsv
Xiang, Haihao
haihao.xiang at intel.com
Tue Mar 23 06:27:01 EET 2021
On Mon, 2021-03-22 at 14:35 +0800, wenbin.chen at intel.com wrote:
> From: "Chen,Wenbin" <wenbin.chen at intel.com>
>
> ChromaForamt for mjpeg-qsv is always set to yuv420, and this will be
> wrong when encode other pixel format (for example yuyv422). I change
> this assignment to be adaptive to pix_fmt.
>
> Signed-off-by: Wenbin Chen <wenbin.chen at intel.com>
> ---
> libavcodec/qsvenc.c | 3 ++-
> 1 file changed, 2 insertions(+), 1 deletion(-)
>
> diff --git a/libavcodec/qsvenc.c b/libavcodec/qsvenc.c
> index 566a5c8552..a0fc206364 100644
> --- a/libavcodec/qsvenc.c
> +++ b/libavcodec/qsvenc.c
> @@ -445,7 +445,8 @@ static int init_video_param_jpeg(AVCodecContext *avctx,
> QSVEncContext *q)
> q->param.mfx.FrameInfo.CropH = avctx->height;
> q->param.mfx.FrameInfo.AspectRatioW = avctx->sample_aspect_ratio.num;
> q->param.mfx.FrameInfo.AspectRatioH = avctx->sample_aspect_ratio.den;
> - q->param.mfx.FrameInfo.ChromaFormat = MFX_CHROMAFORMAT_YUV420;
> + q->param.mfx.FrameInfo.ChromaFormat = MFX_CHROMAFORMAT_YUV420 +
> + !desc->log2_chroma_w + !desc-
> >log2_chroma_h;
> q->param.mfx.FrameInfo.BitDepthLuma = desc->comp[0].depth;
> q->param.mfx.FrameInfo.BitDepthChroma = desc->comp[0].depth;
> q->param.mfx.FrameInfo.Shift = desc->comp[0].depth > 8;
LGTM, thank!
-Haihao
More information about the ffmpeg-devel
mailing list