ref: 8662a55bc3c1307b3f04e44ae2c9771b66229560
parent: 61017a2d4dd474ac7f1a507a13dbd19c40e9c89d
parent: ce870bf20e47fbb003f1a0df29e13a3aa3332750
author: dongzha <[email protected]>
date: Tue Jun 17 07:18:11 EDT 2014
Merge pull request #973 from ruil2/bitrate add bitrate validation
--- a/codec/encoder/core/src/encoder_ext.cpp
+++ b/codec/encoder/core/src/encoder_ext.cpp
@@ -112,21 +112,30 @@
|| fMaxFrameRate - pCfg->fMaxFrameRate < -fEpsn)) {
pCfg->fMaxFrameRate = fMaxFrameRate;
}
-
- //bitrate setting validation
+//bitrate setting validation
if (pCfg->iRCMode != RC_OFF_MODE) {
int32_t iTotalBitrate = 0;
+ if (pCfg->iTargetBitrate <= 0) {
+ WelsLog (pLogCtx, WELS_LOG_ERROR, "Invalid bitrate settings in total configure, bitrate= %d\n", pCfg->iTargetBitrate);
+ return ENC_RETURN_INVALIDINPUT;
+ }
for (i = 0; i < pCfg->iSpatialLayerNum; ++ i) {
SSpatialLayerConfig* pSpatialLayer = &pCfg->sSpatialLayers[i];
iTotalBitrate += pSpatialLayer->iSpatialBitrate;
+ if (pSpatialLayer->iSpatialBitrate <= 0) {
+ WelsLog (pLogCtx, WELS_LOG_ERROR, "Invalid bitrate settings in layer %d, bitrate= %d\n", i,
+ pSpatialLayer->iSpatialBitrate);
+ return ENC_RETURN_INVALIDINPUT;
+ }
}
if (iTotalBitrate > pCfg->iTargetBitrate) {
WelsLog (pLogCtx, WELS_LOG_ERROR,
"Invalid settings in bitrate. the sum of each layer bitrate(%d) is larger than total bitrate setting(%d)\n",
iTotalBitrate, pCfg->iTargetBitrate);
+ return ENC_RETURN_INVALIDINPUT;
}
- }
+ }
return ENC_RETURN_SUCCESS;
}