msdkh264enc: Add intra refresh parameters

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/2308>
This commit is contained in:
Mengkejiergeli Ba 2022-04-15 13:38:20 +08:00 committed by Haihao Xiang
parent aa835f5e64
commit 9c8cb97db9
2 changed files with 66 additions and 13 deletions

View file

@ -74,6 +74,9 @@ enum
PROP_MIN_QP, PROP_MIN_QP,
PROP_MAX_QP, PROP_MAX_QP,
PROP_INTRA_REFRESH_TYPE, PROP_INTRA_REFRESH_TYPE,
PROP_INTRA_REFRESH_CYCLE_SIZE,
PROP_INTRA_REFRESH_QP_DELTA,
PROP_INTRA_REFRESH_CYCLE_DIST,
PROP_DBLK_IDC, PROP_DBLK_IDC,
}; };
@ -95,6 +98,9 @@ enum
#define PROP_MIN_QP_DEFAULT 0 #define PROP_MIN_QP_DEFAULT 0
#define PROP_MAX_QP_DEFAULT 0 #define PROP_MAX_QP_DEFAULT 0
#define PROP_INTRA_REFRESH_TYPE_DEFAULT MFX_REFRESH_NO #define PROP_INTRA_REFRESH_TYPE_DEFAULT MFX_REFRESH_NO
#define PROP_INTRA_REFRESH_CYCLE_SIZE_DEFAULT 0
#define PROP_INTRA_REFRESH_QP_DELTA_DEFAULT 0
#define PROP_INTRA_REFRESH_CYCLE_DIST_DEFAULT 0
#define PROP_DBLK_IDC_DEFAULT 0 #define PROP_DBLK_IDC_DEFAULT 0
static GstStaticPadTemplate src_factory = GST_STATIC_PAD_TEMPLATE ("src", static GstStaticPadTemplate src_factory = GST_STATIC_PAD_TEMPLATE ("src",
@ -407,6 +413,8 @@ gst_msdkh264enc_configure (GstMsdkEnc * encoder)
encoder->option2.MaxQPI = encoder->option2.MaxQPP = encoder->option2.MaxQPB = encoder->option2.MaxQPI = encoder->option2.MaxQPP = encoder->option2.MaxQPB =
thiz->max_qp; thiz->max_qp;
encoder->option2.IntRefType = thiz->intra_refresh_type; encoder->option2.IntRefType = thiz->intra_refresh_type;
encoder->option2.IntRefCycleSize = thiz->intra_refresh_cycle_size;
encoder->option2.IntRefQPDelta = thiz->intra_refresh_qp_delta;
encoder->option2.DisableDeblockingIdc = thiz->dblk_idc; encoder->option2.DisableDeblockingIdc = thiz->dblk_idc;
if (encoder->rate_control == MFX_RATECONTROL_LA || if (encoder->rate_control == MFX_RATECONTROL_LA ||
@ -427,6 +435,9 @@ gst_msdkh264enc_configure (GstMsdkEnc * encoder)
encoder->param.mfx.GopRefDist = 1; encoder->param.mfx.GopRefDist = 1;
/* SDK decides the DPB size for P pyramid */ /* SDK decides the DPB size for P pyramid */
encoder->param.mfx.NumRefFrame = 0; encoder->param.mfx.NumRefFrame = 0;
}
if (thiz->intra_refresh_cycle_dist) {
encoder->option3.IntRefCycleDist = thiz->intra_refresh_cycle_dist;
encoder->enable_extopt3 = TRUE; encoder->enable_extopt3 = TRUE;
} }
@ -611,6 +622,15 @@ gst_msdkh264enc_set_property (GObject * object, guint prop_id,
case PROP_INTRA_REFRESH_TYPE: case PROP_INTRA_REFRESH_TYPE:
thiz->intra_refresh_type = g_value_get_enum (value); thiz->intra_refresh_type = g_value_get_enum (value);
break; break;
case PROP_INTRA_REFRESH_CYCLE_SIZE:
thiz->intra_refresh_cycle_size = g_value_get_uint (value);
break;
case PROP_INTRA_REFRESH_QP_DELTA:
thiz->intra_refresh_qp_delta = g_value_get_int (value);
break;
case PROP_INTRA_REFRESH_CYCLE_DIST:
thiz->intra_refresh_cycle_dist = g_value_get_uint (value);
break;
case PROP_DBLK_IDC: case PROP_DBLK_IDC:
thiz->dblk_idc = g_value_get_uint (value); thiz->dblk_idc = g_value_get_uint (value);
break; break;
@ -671,6 +691,15 @@ gst_msdkh264enc_get_property (GObject * object, guint prop_id, GValue * value,
case PROP_INTRA_REFRESH_TYPE: case PROP_INTRA_REFRESH_TYPE:
g_value_set_enum (value, thiz->intra_refresh_type); g_value_set_enum (value, thiz->intra_refresh_type);
break; break;
case PROP_INTRA_REFRESH_CYCLE_SIZE:
g_value_set_uint (value, thiz->intra_refresh_cycle_size);
break;
case PROP_INTRA_REFRESH_QP_DELTA:
g_value_set_int (value, thiz->intra_refresh_qp_delta);
break;
case PROP_INTRA_REFRESH_CYCLE_DIST:
g_value_set_uint (value, thiz->intra_refresh_cycle_dist);
break;
case PROP_DBLK_IDC: case PROP_DBLK_IDC:
g_value_set_uint (value, thiz->dblk_idc); g_value_set_uint (value, thiz->dblk_idc);
break; break;
@ -799,6 +828,24 @@ gst_msdkh264enc_class_init (GstMsdkH264EncClass * klass)
PROP_INTRA_REFRESH_TYPE_DEFAULT, PROP_INTRA_REFRESH_TYPE_DEFAULT,
G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS)); G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
g_object_class_install_property (gobject_class, PROP_INTRA_REFRESH_CYCLE_SIZE,
g_param_spec_uint ("intra-refresh-cycle-size", "Intra refresh cycle size",
"Set intra refresh cycle size, valid value starts from 2",
0, G_MAXUINT16, PROP_INTRA_REFRESH_CYCLE_SIZE_DEFAULT,
G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
g_object_class_install_property (gobject_class, PROP_INTRA_REFRESH_QP_DELTA,
g_param_spec_int ("intra-refresh-qp-delta", "Intra refresh qp delta",
"Set intra refresh qp delta",
-51, 51, PROP_INTRA_REFRESH_QP_DELTA_DEFAULT,
G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
g_object_class_install_property (gobject_class, PROP_INTRA_REFRESH_CYCLE_DIST,
g_param_spec_uint ("intra-refresh-cycle-dist", "Intra refresh cycle dist",
"Set intra refresh cycle dist",
0, G_MAXUINT16, PROP_INTRA_REFRESH_CYCLE_DIST_DEFAULT,
G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
g_object_class_install_property (gobject_class, PROP_DBLK_IDC, g_object_class_install_property (gobject_class, PROP_DBLK_IDC,
g_param_spec_uint ("dblk-idc", "Disable Deblocking Idc", g_param_spec_uint ("dblk-idc", "Disable Deblocking Idc",
"Option of disable deblocking idc", "Option of disable deblocking idc",
@ -827,5 +874,8 @@ gst_msdkh264enc_init (GstMsdkH264Enc * thiz)
thiz->min_qp = PROP_MIN_QP_DEFAULT; thiz->min_qp = PROP_MIN_QP_DEFAULT;
thiz->max_qp = PROP_MAX_QP_DEFAULT; thiz->max_qp = PROP_MAX_QP_DEFAULT;
thiz->intra_refresh_type = PROP_INTRA_REFRESH_TYPE_DEFAULT; thiz->intra_refresh_type = PROP_INTRA_REFRESH_TYPE_DEFAULT;
thiz->intra_refresh_cycle_size = PROP_INTRA_REFRESH_CYCLE_SIZE_DEFAULT;
thiz->intra_refresh_qp_delta = PROP_INTRA_REFRESH_QP_DELTA_DEFAULT;
thiz->intra_refresh_cycle_dist = PROP_INTRA_REFRESH_CYCLE_DIST_DEFAULT;
thiz->dblk_idc = PROP_DBLK_IDC_DEFAULT; thiz->dblk_idc = PROP_DBLK_IDC_DEFAULT;
} }

View file

@ -75,6 +75,9 @@ struct _GstMsdkH264Enc
guint min_qp; guint min_qp;
guint max_qp; guint max_qp;
guint intra_refresh_type; guint intra_refresh_type;
guint intra_refresh_cycle_size;
gint intra_refresh_qp_delta;
guint intra_refresh_cycle_dist;
guint dblk_idc; guint dblk_idc;
GstH264NalParser *parser; GstH264NalParser *parser;