ref: 46d1c93016ff2b2faa9f0f716acb1e6770adb69b
parent: 2f0b6c8f14acbe6c9f60a5867f6fbd52734c3063
 parent: cf3845779f0e6a8b7806d40d62443514e36c63c1
	author: HaiboZhu <haibozhu@cisco.com>
	date: Mon Apr 13 06:24:28 EDT 2015
	
Merge pull request #1892 from huili2/bugfix_greenissue_parseonly bugfix for HW decoding green issue
--- a/codec/decoder/core/src/decoder_core.cpp
+++ b/codec/decoder/core/src/decoder_core.cpp
@@ -112,8 +112,6 @@
pDstBuf += pPpsBs->uiPpsBsLen;
pCtx->bFrameFinish = false;
}
-      } else { //IDR required SPS, PPS- pCtx->bFrameFinish = true;
}
//then VCL data re-write
       while (iIdx <= iEndIdx) {@@ -127,9 +125,11 @@
       if (pCtx->iTotalNumMbRec == kiTotalNumMbInCurLayer) { //frame completepCtx->iTotalNumMbRec = 0;
pCtx->bFramePending = false;
+ pCtx->bFrameFinish = true; //finish current frame and mark it
       } else if (pCtx->iTotalNumMbRec != 0) { //frame incompletepCtx->bFramePending = true;
pCtx->pDec->bIsComplete = false;
+ pCtx->bFrameFinish = false; //current frame not finished
pCtx->iErrorCode |= dsFramePending;
return -1;
//pCtx->pParserBsInfo->iNalNum = 0;
@@ -2099,6 +2099,8 @@
pCtx->iErrorCode |= dsOutOfMemory;
return ERR_INFO_REF_COUNT_OVERFLOW;
}
+ pCtx->pDec->bNewSeqBegin = pCtx->bNewSeqBegin; //set flag for start decoding
+    } else if (pCtx->iTotalNumMbRec == 0) { //pDec != NULL, already startpCtx->pDec->bNewSeqBegin = pCtx->bNewSeqBegin; //set flag for start decoding
}
pCtx->pDec->uiTimeStamp = pNalCur->uiTimeStamp;
--
⑨