ref: aa2cfef31082d501776c1786ff315665f4da43e1
parent: 2b038fa73b2b9ff2abef1e45f7e4db741835cf6e
parent: ce5268076ca9b0aee66fd802d0fc46e3574af4f9
author: ruil2 <[email protected]>
date: Tue Jul 1 04:50:52 EDT 2014
Merge pull request #1048 from ethanhugg/maxnal-revert Revert "add max nal size setting in gmp wrapper"
--- a/module/gmp-openh264.cpp
+++ b/module/gmp-openh264.cpp
@@ -204,95 +204,40 @@
if (rv) {
return GMPVideoGenericErr;
}
- if (maxPayloadSize <= 0) {
- SEncParamBase param;
- memset (¶m, 0, sizeof (param));
- GMPLOG (GL_INFO, "Initializing encoder at "
- << codecSettings.mWidth
- << "x"
- << codecSettings.mHeight
- << "@"
- << static_cast<int> (codecSettings.mMaxFramerate)
- << "max payload size="
- << maxPayloadSize);
+ SEncParamBase param;
+ memset (¶m, 0, sizeof (param));
- // Translate parameters.
- param.iUsageType = CAMERA_VIDEO_REAL_TIME;
- param.iPicWidth = codecSettings.mWidth;
- param.iPicHeight = codecSettings.mHeight;
- param.iTargetBitrate = codecSettings.mStartBitrate * 1000;
- GMPLOG (GL_INFO, "Initializing Bit Rate at: Start: "
- << codecSettings.mStartBitrate
- << "; Min: "
- << codecSettings.mMinBitrate
- << "; Max: "
- << codecSettings.mMaxBitrate);
+ GMPLOG (GL_INFO, "Initializing encoder at "
+ << codecSettings.mWidth
+ << "x"
+ << codecSettings.mHeight
+ << "@"
+ << static_cast<int> (codecSettings.mMaxFramerate)
+ << "max payload size="
+ << maxPayloadSize);
- param.iRCMode = RC_BITRATE_MODE;
+ // Translate parameters.
+ param.iUsageType = CAMERA_VIDEO_REAL_TIME;
+ param.iPicWidth = codecSettings.mWidth;
+ param.iPicHeight = codecSettings.mHeight;
+ param.iTargetBitrate = codecSettings.mStartBitrate * 1000;
+ GMPLOG (GL_INFO, "Initializing Bit Rate at: Start: "
+ << codecSettings.mStartBitrate
+ << "; Min: "
+ << codecSettings.mMinBitrate
+ << "; Max: "
+ << codecSettings.mMaxBitrate);
+ param.iRCMode = RC_BITRATE_MODE;
- // TODO([email protected]). Scary conversion from unsigned char to float below.
- param.fMaxFrameRate = static_cast<float> (codecSettings.mMaxFramerate);
- param.iInputCsp = videoFormatI420;
+ // TODO([email protected]). Scary conversion from unsigned char to float below.
+ param.fMaxFrameRate = static_cast<float> (codecSettings.mMaxFramerate);
+ param.iInputCsp = videoFormatI420;
- rv = encoder_->Initialize (¶m);
- if (rv) {
- GMPLOG (GL_ERROR, "Couldn't initialize encoder");
- return GMPVideoGenericErr;
- }
- } else {
- SEncParamExt param;
- memset (¶m, 0, sizeof (param));
- encoder_->GetDefaultParams (¶m);
-
- GMPLOG (GL_INFO, "Initializing encoder at "
- << codecSettings.mWidth
- << "x"
- << codecSettings.mHeight
- << "@"
- << static_cast<int> (codecSettings.mMaxFramerate)
- << "max payload size="
- << maxPayloadSize);
-
- // Translate parameters.
- param.iUsageType = CAMERA_VIDEO_REAL_TIME;
- param.iInputCsp = videoFormatI420;
- param.iPicWidth = codecSettings.mWidth;
- param.iPicHeight = codecSettings.mHeight;
- param.iRCMode = RC_BITRATE_MODE;
- param.iTargetBitrate = codecSettings.mStartBitrate * 1000;
- param.iMaxBitrate = codecSettings.mMaxBitrate * 1000;
- GMPLOG (GL_INFO, "Initializing Bit Rate at: Start: "
- << codecSettings.mStartBitrate
- << "; Min: "
- << codecSettings.mMinBitrate
- << "; Max: "
- << codecSettings.mMaxBitrate);
- //for controlling the NAL size (normally for packetization-mode=0)
- param.uiMaxNalSize = maxPayloadSize;
-
- // TODO([email protected]). Scary conversion from unsigned char to float below.
- param.fMaxFrameRate = static_cast<float> (codecSettings.mMaxFramerate);
-
- // Set up layers. Currently we have one layer.
- SSpatialLayerConfig* layer = ¶m.sSpatialLayers[0];
-
- layer->iVideoWidth = codecSettings.mWidth;
- layer->iVideoHeight = codecSettings.mHeight;
- layer->fFrameRate = param.fMaxFrameRate;
- layer->iSpatialBitrate = param.iTargetBitrate;
- layer->iMaxSpatialBitrate = param.iMaxBitrate;
-
- // Based on guidance from Cisco.
- layer->sSliceCfg.uiSliceMode = SM_DYN_SLICE;
- layer->sSliceCfg.sSliceArgument.uiSliceSizeConstraint = maxPayloadSize;
-
- rv = encoder_->InitializeExt (¶m);
- if (rv) {
- GMPLOG (GL_ERROR, "Couldn't initialize encoder");
- return GMPVideoGenericErr;
- }
-
+ rv = encoder_->Initialize (¶m);
+ if (rv) {
+ GMPLOG (GL_ERROR, "Couldn't initialize encoder");
+ return GMPVideoGenericErr;
}
max_payload_size_ = maxPayloadSize;