浏览代码

obs-qsv: Enable LA_CBR as QSV rate control

Allow user to choose look ahead CBR as the rate control method for QSV.
Also, changes look ahead depth default to 15 when used.
brittneysclark 6 年之前
父节点
当前提交
2f62831a96
共有 3 个文件被更改,包括 23 次插入14 次删除
  1. 4 4
      plugins/obs-qsv11/QSV_Encoder.h
  2. 4 2
      plugins/obs-qsv11/QSV_Encoder_Internal.cpp
  3. 15 8
      plugins/obs-qsv11/obs-qsv11.c

+ 4 - 4
plugins/obs-qsv11/QSV_Encoder.h

@@ -70,9 +70,9 @@ struct qsv_rate_control_info {
 };
 };
 
 
 static const struct qsv_rate_control_info qsv_ratecontrols[] = {
 static const struct qsv_rate_control_info qsv_ratecontrols[] = {
-	{"CBR", false},   {"VBR", false},  {"VCM", true},
-	{"CQP", false},   {"AVBR", false}, {"ICQ", true},
-	{"LA_ICQ", true}, {"LA", true},    {0, false}};
+	{"CBR", false},   {"VBR", false}, {"VCM", true},    {"CQP", false},
+	{"AVBR", false},  {"ICQ", true},  {"LA_ICQ", true}, {"LA_CBR", true},
+	{"LA_VBR", true}, {0, false}};
 static const char *const qsv_profile_names[] = {"high", "main", "baseline", 0};
 static const char *const qsv_profile_names[] = {"high", "main", "baseline", 0};
 static const char *const qsv_usage_names[] = {"quality", "balanced", "speed",
 static const char *const qsv_usage_names[] = {"quality", "balanced", "speed",
 					      0};
 					      0};
@@ -112,7 +112,7 @@ enum qsv_cpu_platform {
 	QSV_CPU_PLATFORM_CHT,
 	QSV_CPU_PLATFORM_CHT,
 	QSV_CPU_PLATFORM_HSW,
 	QSV_CPU_PLATFORM_HSW,
 	QSV_CPU_PLATFORM_BDW,
 	QSV_CPU_PLATFORM_BDW,
-	QSV_CPU_PLATFORM_SKL,  
+	QSV_CPU_PLATFORM_SKL,
 	QSV_CPU_PLATFORM_INTEL
 	QSV_CPU_PLATFORM_INTEL
 };
 };
 
 

+ 4 - 2
plugins/obs-qsv11/QSV_Encoder_Internal.cpp

@@ -240,6 +240,9 @@ bool QSV_Encoder_Internal::InitParams(qsv_param_t *pParams)
 		break;
 		break;
 	case MFX_RATECONTROL_LA_ICQ:
 	case MFX_RATECONTROL_LA_ICQ:
 		m_mfxEncParams.mfx.ICQQuality = pParams->nICQQuality;
 		m_mfxEncParams.mfx.ICQQuality = pParams->nICQQuality;
+	case MFX_RATECONTROL_LA_HRD:
+		m_mfxEncParams.mfx.TargetKbps = pParams->nTargetBitRate;
+		m_mfxEncParams.mfx.MaxKbps = pParams->nTargetBitRate;
 		break;
 		break;
 	default:
 	default:
 		break;
 		break;
@@ -261,8 +264,7 @@ bool QSV_Encoder_Internal::InitParams(qsv_param_t *pParams)
 		extendedBuffers[iBuffers++] = (mfxExtBuffer *)&m_co;
 		extendedBuffers[iBuffers++] = (mfxExtBuffer *)&m_co;
 	}
 	}
 
 
-	if (m_ver.Major == 1 && m_ver.Minor >= 8)
-	{
+	if (m_ver.Major == 1 && m_ver.Minor >= 8) {
 		memset(&m_co2, 0, sizeof(mfxExtCodingOption2));
 		memset(&m_co2, 0, sizeof(mfxExtCodingOption2));
 		m_co2.Header.BufferId = MFX_EXTBUFF_CODING_OPTION2;
 		m_co2.Header.BufferId = MFX_EXTBUFF_CODING_OPTION2;
 		m_co2.Header.BufferSz = sizeof(m_co2);
 		m_co2.Header.BufferSz = sizeof(m_co2);

+ 15 - 8
plugins/obs-qsv11/obs-qsv11.c

@@ -155,7 +155,7 @@ static void obs_qsv_defaults(obs_data_t *settings)
 	obs_data_set_default_int(settings, "qpp", 23);
 	obs_data_set_default_int(settings, "qpp", 23);
 	obs_data_set_default_int(settings, "qpb", 23);
 	obs_data_set_default_int(settings, "qpb", 23);
 	obs_data_set_default_int(settings, "icq_quality", 23);
 	obs_data_set_default_int(settings, "icq_quality", 23);
-	obs_data_set_default_int(settings, "la_depth", 40);
+	obs_data_set_default_int(settings, "la_depth", 15);
 
 
 	obs_data_set_default_int(settings, "keyint_sec", 3);
 	obs_data_set_default_int(settings, "keyint_sec", 3);
 	obs_data_set_default_int(settings, "bframes", 3);
 	obs_data_set_default_int(settings, "bframes", 3);
@@ -226,13 +226,14 @@ static bool rate_control_modified(obs_properties_t *ppts, obs_property_t *p,
 	obs_property_set_visible(p, bVisible);
 	obs_property_set_visible(p, bVisible);
 
 
 	bVisible = astrcmpi(rate_control, "LA_ICQ") == 0 ||
 	bVisible = astrcmpi(rate_control, "LA_ICQ") == 0 ||
-		   astrcmpi(rate_control, "LA") == 0;
+		   astrcmpi(rate_control, "LA_CBR") == 0 ||
+		   astrcmpi(rate_control, "LA_VBR") == 0;
 	p = obs_properties_get(ppts, "la_depth");
 	p = obs_properties_get(ppts, "la_depth");
 	obs_property_set_visible(p, bVisible);
 	obs_property_set_visible(p, bVisible);
 
 
 	bVisible = astrcmpi(rate_control, "CBR") == 0 ||
 	bVisible = astrcmpi(rate_control, "CBR") == 0 ||
-		    astrcmpi(rate_control, "VBR") == 0 ||
-		    astrcmpi(rate_control, "AVBR") == 0;
+		   astrcmpi(rate_control, "VBR") == 0 ||
+		   astrcmpi(rate_control, "AVBR") == 0;
 	p = obs_properties_get(ppts, "mbbrc");
 	p = obs_properties_get(ppts, "mbbrc");
 	obs_property_set_visible(p, bVisible);
 	obs_property_set_visible(p, bVisible);
 
 
@@ -371,8 +372,10 @@ static void update_params(struct obs_qsv *obsqsv, obs_data_t *settings)
 		obsqsv->params.nRateControl = MFX_RATECONTROL_ICQ;
 		obsqsv->params.nRateControl = MFX_RATECONTROL_ICQ;
 	else if (astrcmpi(rate_control, "LA_ICQ") == 0)
 	else if (astrcmpi(rate_control, "LA_ICQ") == 0)
 		obsqsv->params.nRateControl = MFX_RATECONTROL_LA_ICQ;
 		obsqsv->params.nRateControl = MFX_RATECONTROL_LA_ICQ;
-	else if (astrcmpi(rate_control, "LA") == 0)
+	else if (astrcmpi(rate_control, "LA_VBR") == 0)
 		obsqsv->params.nRateControl = MFX_RATECONTROL_LA;
 		obsqsv->params.nRateControl = MFX_RATECONTROL_LA;
+	else if (astrcmpi(rate_control, "LA_CBR") == 0)
+		obsqsv->params.nRateControl = MFX_RATECONTROL_LA_HRD;
 
 
 	obsqsv->params.nAsyncDepth = (mfxU16)async_depth;
 	obsqsv->params.nAsyncDepth = (mfxU16)async_depth;
 	obsqsv->params.nAccuracy = (mfxU16)accuracy;
 	obsqsv->params.nAccuracy = (mfxU16)accuracy;
@@ -411,7 +414,8 @@ static void update_params(struct obs_qsv *obsqsv, obs_data_t *settings)
 		     (int)obsqsv->params.nICQQuality);
 		     (int)obsqsv->params.nICQQuality);
 
 
 	if (obsqsv->params.nRateControl == MFX_RATECONTROL_LA_ICQ ||
 	if (obsqsv->params.nRateControl == MFX_RATECONTROL_LA_ICQ ||
-	    obsqsv->params.nRateControl == MFX_RATECONTROL_LA)
+	    obsqsv->params.nRateControl == MFX_RATECONTROL_LA ||
+	    obsqsv->params.nRateControl == MFX_RATECONTROL_LA_HRD)
 		blog(LOG_INFO, "\tLookahead Depth:%d",
 		blog(LOG_INFO, "\tLookahead Depth:%d",
 		     (int)obsqsv->params.nLADEPTH);
 		     (int)obsqsv->params.nLADEPTH);
 
 
@@ -639,7 +643,8 @@ static void parse_packet(struct obs_qsv *obsqsv, struct encoder_packet *packet,
 
 
 	if (frameType & MFX_FRAMETYPE_I)
 	if (frameType & MFX_FRAMETYPE_I)
 		priority = OBS_NAL_PRIORITY_HIGHEST;
 		priority = OBS_NAL_PRIORITY_HIGHEST;
-	else if ((frameType & MFX_FRAMETYPE_P) || (frameType & MFX_FRAMETYPE_REF))
+	else if ((frameType & MFX_FRAMETYPE_P) ||
+		 (frameType & MFX_FRAMETYPE_REF))
 		priority = OBS_NAL_PRIORITY_HIGH;
 		priority = OBS_NAL_PRIORITY_HIGH;
 	else
 	else
 		priority = 0;
 		priority = 0;
@@ -662,7 +667,9 @@ static void parse_packet(struct obs_qsv *obsqsv, struct encoder_packet *packet,
 		type = start[0] & 0x1F;
 		type = start[0] & 0x1F;
 		if (type == OBS_NAL_SLICE_IDR || type == OBS_NAL_SLICE) {
 		if (type == OBS_NAL_SLICE_IDR || type == OBS_NAL_SLICE) {
 			start[0] &= ~(3 << 5);
 			start[0] &= ~(3 << 5);
-			start[0] |= priority << 5; //0 for non-ref frames and not equal to 0 for ref frames
+			start[0] |=
+				priority
+				<< 5; //0 for non-ref frames and not equal to 0 for ref frames
 		}
 		}
 
 
 		start = (uint8_t *)obs_avc_find_startcode(start, end);
 		start = (uint8_t *)obs_avc_find_startcode(start, end);