ref: 50ce93e31ce25edbe17a56661d61b2cf56abe351
parent: aea1017562d48a83ca1acfb2ba7f9ef74e8dfd1e
author: huili2 <[email protected]>
date: Sun Jan 18 13:07:27 EST 2015
modify EC init position
--- a/codec/decoder/core/src/decoder.cpp
+++ b/codec/decoder/core/src/decoder.cpp
@@ -459,7 +459,6 @@
//initial MC function pointer--
int iRet = ERR_NONE;
InitMcFunc (& (pCtx->sMcFunc), pCtx->uiCpuFlag);
- InitErrorCon (pCtx);
InitExpandPictureFunc (& (pCtx->sExpandPicFunc), pCtx->uiCpuFlag);
AssignFuncPointerForRec (pCtx);
@@ -525,6 +524,7 @@
if (pCtx->bParseOnly) //parse only, disable EC method
pCtx->eErrorConMethod = ERROR_CON_DISABLE;
+ InitErrorCon (pCtx);
if (VIDEO_BITSTREAM_SVC == pCtx->pParam->sVideoProperty.eVideoBsType ||
VIDEO_BITSTREAM_AVC == pCtx->pParam->sVideoProperty.eVideoBsType) {
--- a/test/decoder/DecUT_DecExt.cpp
+++ b/test/decoder/DecUT_DecExt.cpp
@@ -81,7 +81,7 @@
m_sDecParam.eOutputColorFormat = (EVideoFormatType) (rand() % 100);
m_sDecParam.uiCpuLoad = rand() % 100;
m_sDecParam.uiTargetDqLayer = rand() % 100;
- m_sDecParam.eEcActiveIdc = (ERROR_CON_IDC) (rand() & 3);
+ m_sDecParam.eEcActiveIdc = (ERROR_CON_IDC) (rand() & 7);
m_sDecParam.sVideoProperty.size = sizeof (SVideoProperty);
m_sDecParam.sVideoProperty.eVideoBsType = (VIDEO_BITSTREAM_TYPE) (rand() % 3);
@@ -379,7 +379,33 @@
//DECODER_OPTION_ERROR_CON_IDC
void DecoderInterfaceTest::TestErrorConIdc() {
- //TODO
+ int iTmp, iOut;
+ CM_RETURN eRet;
+
+ Init();
+
+ //Test GetOption
+ //invalid input
+ eRet = (CM_RETURN) m_pDec->GetOption (DECODER_OPTION_ERROR_CON_IDC, NULL);
+ EXPECT_EQ (eRet, cmInitParaError);
+
+ //Test GetOption
+ //valid input
+ eRet = (CM_RETURN) m_pDec->GetOption (DECODER_OPTION_ERROR_CON_IDC, &iOut);
+ EXPECT_EQ (eRet, cmResultSuccess);
+
+ //Test SetOption
+ iTmp = rand() & 7;
+ eRet = (CM_RETURN) m_pDec->SetOption (DECODER_OPTION_ERROR_CON_IDC, &iTmp);
+ EXPECT_EQ (eRet, cmResultSuccess);
+
+ //Test GetOption
+ eRet = (CM_RETURN) m_pDec->GetOption (DECODER_OPTION_ERROR_CON_IDC, &iOut);
+ EXPECT_EQ (eRet, cmResultSuccess);
+ EXPECT_EQ (iTmp, iOut);
+
+ Uninit();
+
}
//DECODER_OPTION_TRACE_LEVEL