]> git.sesse.net Git - ffmpeg/commitdiff
lavc/qsvdec: fix hevc level incorrectly map
authorZhong Li <zhong.li@intel.com>
Sun, 28 Apr 2019 09:15:55 +0000 (17:15 +0800)
committerZhong Li <zhong.li@intel.com>
Tue, 7 May 2019 03:00:14 +0000 (11:00 +0800)
libmfx hevc level defination is same as h264, not level_idc of SPEC.

Signed-off-by: Zhong Li <zhong.li@intel.com>
libavcodec/qsv.c
libavcodec/qsv_internal.h
libavcodec/qsvdec.c

index bb0d79588c4d66e0fd149bd8be6fec4f9d076d8a..4d3fbafe044d5cc9790b092a21ec1299c08314b4 100644 (file)
@@ -83,6 +83,19 @@ int ff_qsv_profile_to_mfx(enum AVCodecID codec_id, int profile)
     return MFX_PROFILE_UNKNOWN;
 }
 
+int ff_qsv_level_to_mfx(enum AVCodecID codec_id, int level)
+{
+    if (level == FF_LEVEL_UNKNOWN)
+        return MFX_LEVEL_UNKNOWN;
+
+    switch (codec_id) {
+    case AV_CODEC_ID_HEVC:
+        return level / 3;
+    default:
+        return level;
+    }
+}
+
 static const struct {
     mfxStatus   mfxerr;
     int         averr;
index 57d861d2be07927cd82bf186aa2a370d81435d7e..b63a7d6a31e64f9e02151c38984fa942973b3f1c 100644 (file)
@@ -90,6 +90,7 @@ int ff_qsv_print_warning(void *log_ctx, mfxStatus err,
 
 int ff_qsv_codec_id_to_mfx(enum AVCodecID codec_id);
 int ff_qsv_profile_to_mfx(enum AVCodecID codec_id, int profile);
+int ff_qsv_level_to_mfx(enum AVCodecID codec_id, int level);
 
 int ff_qsv_map_pixfmt(enum AVPixelFormat format, uint32_t *fourcc);
 enum AVPictureType ff_qsv_map_pictype(int mfx_pic_type);
index 2a8a032111d7f9f121be26485e32e2b31029afcc..46aa2d681475701c6697335521627a372e39d59a 100644 (file)
@@ -203,7 +203,7 @@ static int qsv_decode_init(AVCodecContext *avctx, QSVContext *q)
 
     param.mfx.CodecId      = ret;
     param.mfx.CodecProfile = ff_qsv_profile_to_mfx(avctx->codec_id, avctx->profile);
-    param.mfx.CodecLevel   = avctx->level == FF_LEVEL_UNKNOWN ? MFX_LEVEL_UNKNOWN : avctx->level;
+    param.mfx.CodecLevel   = ff_qsv_level_to_mfx(avctx->codec_id, avctx->level);
 
     param.mfx.FrameInfo.BitDepthLuma   = desc->comp[0].depth;
     param.mfx.FrameInfo.BitDepthChroma = desc->comp[0].depth;