[FFmpeg-devel] [PATCH 2/2] lavc/qsvenc: pass the color properties to the SDK
Haihao Xiang
haihao.xiang at intel.com
Wed Jul 28 11:15:47 EEST 2021
Otherwise the color properties won't be encoded into the bitstream
header
---
libavcodec/qsvenc.c | 18 ++++++++++++++++++
libavcodec/qsvenc.h | 4 +++-
2 files changed, 21 insertions(+), 1 deletion(-)
diff --git a/libavcodec/qsvenc.c b/libavcodec/qsvenc.c
index f6fa759447..e7e65ebfcf 100644
--- a/libavcodec/qsvenc.c
+++ b/libavcodec/qsvenc.c
@@ -805,6 +805,24 @@ static int init_video_param(AVCodecContext *avctx, QSVEncContext *q)
}
#endif
+ q->extvsi.VideoFullRange = (avctx->color_range == AVCOL_RANGE_JPEG);
+ q->extvsi.ColourDescriptionPresent = 0;
+
+ if (avctx->color_primaries != AVCOL_PRI_UNSPECIFIED ||
+ avctx->color_trc != AVCOL_TRC_UNSPECIFIED ||
+ avctx->colorspace != AVCOL_SPC_UNSPECIFIED) {
+ q->extvsi.ColourDescriptionPresent = 1;
+ q->extvsi.ColourPrimaries = avctx->color_primaries;
+ q->extvsi.TransferCharacteristics = avctx->color_trc;
+ q->extvsi.MatrixCoefficients = avctx->colorspace;
+ }
+
+ if (q->extvsi.VideoFullRange || q->extvsi.ColourDescriptionPresent) {
+ q->extvsi.Header.BufferId = MFX_EXTBUFF_VIDEO_SIGNAL_INFO;
+ q->extvsi.Header.BufferSz = sizeof(q->extvsi);
+ q->extparam_internal[q->nb_extparam_internal++] = (mfxExtBuffer *)&q->extvsi;
+ }
+
if (!check_enc_param(avctx,q)) {
av_log(avctx, AV_LOG_ERROR,
"some encoding parameters are not supported by the QSV "
diff --git a/libavcodec/qsvenc.h b/libavcodec/qsvenc.h
index 6d305f87dd..fc8a14143e 100644
--- a/libavcodec/qsvenc.h
+++ b/libavcodec/qsvenc.h
@@ -139,7 +139,9 @@ typedef struct QSVEncContext {
mfxFrameSurface1 **opaque_surfaces;
AVBufferRef *opaque_alloc_buf;
- mfxExtBuffer *extparam_internal[2 + QSV_HAVE_CO2 + QSV_HAVE_CO3 + (QSV_HAVE_MF * 2)];
+ mfxExtVideoSignalInfo extvsi;
+
+ mfxExtBuffer *extparam_internal[3 + QSV_HAVE_CO2 + QSV_HAVE_CO3 + (QSV_HAVE_MF * 2)];
int nb_extparam_internal;
mfxExtBuffer **extparam;
--
2.17.1
More information about the ffmpeg-devel
mailing list