ref: 091e5cba0ae5006914c00ba0387cf29ab680f75f
parent: eeee1a2e9546c84a6cba87510ec702613cc55d0e
parent: c20e1c6795b4159bfa17fca1fc5735b08dfa9256
author: dongzha <[email protected]>
date: Mon Dec 15 08:46:27 EST 2014
Merge pull request #1624 from huili2/au_data_check change au_ready status and check au number
--- a/codec/decoder/core/src/au_parser.cpp
+++ b/codec/decoder/core/src/au_parser.cpp
@@ -271,7 +271,9 @@
if (uiAvailNalNum > 1) {
pCurAu->uiEndPos = uiAvailNalNum - 2;
- pCtx->bAuReadyFlag = true;
+ if (pCtx->eErrorConMethod == ERROR_CON_DISABLE) {
+ pCtx->bAuReadyFlag = true;
+ }
}
pCtx->iErrorCode |= dsBitstreamError;
return NULL;
@@ -291,7 +293,9 @@
if (uiAvailNalNum > 1) {
pCurAu->uiEndPos = uiAvailNalNum - 2;
- pCtx->bAuReadyFlag = true;
+ if (pCtx->eErrorConMethod == ERROR_CON_DISABLE) {
+ pCtx->bAuReadyFlag = true;
+ }
}
pCtx->iErrorCode |= dsBitstreamError;
return NULL;
@@ -340,7 +344,9 @@
ForceClearCurrentNal (pCurAu);
if (uiAvailNalNum > 1) {
pCurAu->uiEndPos = uiAvailNalNum - 2;
- pCtx->bAuReadyFlag = true;
+ if (pCtx->eErrorConMethod == ERROR_CON_DISABLE) {
+ pCtx->bAuReadyFlag = true;
+ }
}
WelsLog (pLogCtx, WELS_LOG_ERROR, "NAL_UNIT_CODED_SLICE: InitBits() fail due invalid access.");
pCtx->iErrorCode |= dsBitstreamError;
@@ -357,7 +363,9 @@
if (uiAvailNalNum > 1) {
pCurAu->uiEndPos = uiAvailNalNum - 2;
- pCtx->bAuReadyFlag = true;
+ if (pCtx->eErrorConMethod == ERROR_CON_DISABLE) {
+ pCtx->bAuReadyFlag = true;
+ }
}
pCtx->iErrorCode |= dsBitstreamError;
return NULL;
--- a/codec/decoder/core/src/decoder.cpp
+++ b/codec/decoder/core/src/decoder.cpp
@@ -642,23 +642,25 @@
pDstNal[iDstIdx] = pDstNal[iDstIdx + 1] = pDstNal[iDstIdx + 2] = pDstNal[iDstIdx + 3] =
0; // set 4 reserved bytes to zero
pNalPayload = ParseNalHeader (pCtx, &pCtx->sCurNalHead, pDstNal, iDstIdx, pSrcNal - 3, iSrcIdx + 3, &iConsumedBytes);
- if (IS_VCL_NAL (pCtx->sCurNalHead.eNalUnitType, 1)) {
- CheckAndFinishLastPic (pCtx, ppDst, pDstBufInfo);
- }
- if (IS_PARAM_SETS_NALS (pCtx->sCurNalHead.eNalUnitType) && pNalPayload) {
- iRet = ParseNonVclNal (pCtx, pNalPayload, iDstIdx - iConsumedBytes, pSrcNal - 3, iSrcIdx + 3);
- }
- if (pCtx->bAuReadyFlag) {
- ConstructAccessUnit (pCtx, ppDst, pDstBufInfo);
+ if (pNalPayload) { //parse correct
+ if (IS_VCL_NAL (pCtx->sCurNalHead.eNalUnitType, 1)) {
+ CheckAndFinishLastPic (pCtx, ppDst, pDstBufInfo);
+ }
+ if (IS_PARAM_SETS_NALS (pCtx->sCurNalHead.eNalUnitType)) {
+ iRet = ParseNonVclNal (pCtx, pNalPayload, iDstIdx - iConsumedBytes, pSrcNal - 3, iSrcIdx + 3);
+ }
+ if (pCtx->bAuReadyFlag) {
+ ConstructAccessUnit (pCtx, ppDst, pDstBufInfo);
- if ((dsOutOfMemory | dsNoParamSets) & pCtx->iErrorCode) {
+ if ((dsOutOfMemory | dsNoParamSets) & pCtx->iErrorCode) {
#ifdef LONG_TERM_REF
- pCtx->bParamSetsLostFlag = true;
+ pCtx->bParamSetsLostFlag = true;
#else
- pCtx->bReferenceLostAtT0Flag = true;
+ pCtx->bReferenceLostAtT0Flag = true;
#endif
- if (dsOutOfMemory & pCtx->iErrorCode) {
- return pCtx->iErrorCode;
+ if (dsOutOfMemory & pCtx->iErrorCode) {
+ return pCtx->iErrorCode;
+ }
}
}
}
@@ -698,22 +700,24 @@
pDstNal[iDstIdx] = pDstNal[iDstIdx + 1] = pDstNal[iDstIdx + 2] = pDstNal[iDstIdx + 3] =
0; // set 4 reserved bytes to zero
pNalPayload = ParseNalHeader (pCtx, &pCtx->sCurNalHead, pDstNal, iDstIdx, pSrcNal - 3, iSrcIdx + 3, &iConsumedBytes);
- if (IS_VCL_NAL (pCtx->sCurNalHead.eNalUnitType, 1)) {
- CheckAndFinishLastPic (pCtx, ppDst, pDstBufInfo);
- }
- if (IS_PARAM_SETS_NALS (pCtx->sCurNalHead.eNalUnitType) && pNalPayload) {
- iRet = ParseNonVclNal (pCtx, pNalPayload, iDstIdx - iConsumedBytes, pSrcNal - 3, iSrcIdx + 3);
- }
- if (pCtx->bAuReadyFlag) {
- ConstructAccessUnit (pCtx, ppDst, pDstBufInfo);
+ if (pNalPayload) { //parse correct
+ if (IS_VCL_NAL (pCtx->sCurNalHead.eNalUnitType, 1)) {
+ CheckAndFinishLastPic (pCtx, ppDst, pDstBufInfo);
+ }
+ if (IS_PARAM_SETS_NALS (pCtx->sCurNalHead.eNalUnitType)) {
+ iRet = ParseNonVclNal (pCtx, pNalPayload, iDstIdx - iConsumedBytes, pSrcNal - 3, iSrcIdx + 3);
+ }
+ if (pCtx->bAuReadyFlag) {
+ ConstructAccessUnit (pCtx, ppDst, pDstBufInfo);
- if ((dsOutOfMemory | dsNoParamSets) & pCtx->iErrorCode) {
+ if ((dsOutOfMemory | dsNoParamSets) & pCtx->iErrorCode) {
#ifdef LONG_TERM_REF
- pCtx->bParamSetsLostFlag = true;
+ pCtx->bParamSetsLostFlag = true;
#else
- pCtx->bReferenceLostAtT0Flag = true;
+ pCtx->bReferenceLostAtT0Flag = true;
#endif
- return pCtx->iErrorCode;
+ return pCtx->iErrorCode;
+ }
}
}
if (iRet) {
--- a/codec/decoder/core/src/decoder_core.cpp
+++ b/codec/decoder/core/src/decoder_core.cpp
@@ -2135,6 +2135,8 @@
bool CheckAndFinishLastPic (PWelsDecoderContext pCtx, uint8_t** ppDst, SBufferInfo* pDstInfo) {
PAccessUnit pAu = pCtx->pAccessUnitList;
+ if (pAu->uiAvailUnitsNum == 0)
+ return true;
PNalUnit pCurNal = pAu->pNalUnitsList[pAu->uiEndPos];
if ((pCtx->iTotalNumMbRec != 0)
&& (CheckAccessUnitBoundaryExt (&pCtx->sLastNalHdrExt, &pCurNal->sNalHeaderExt, &pCtx->sLastSliceHeader,