ref: 173413301253eff8f9a5bbb6baaca43422b32ef2
parent: 4f4adcec4940dd2f96ed4e7d9804f8fd3118e9f8
author: huili2 <[email protected]>
date: Mon Feb 2 17:10:01 EST 2015
bug fix for multi-layer active sps check
--- a/codec/decoder/core/src/au_parser.cpp
+++ b/codec/decoder/core/src/au_parser.cpp
@@ -832,18 +832,30 @@
if (bUseSubsetFlag) {
if (pSps->iMbWidth > 0 && pSps->iMbHeight > 0 && pCtx->bSubspsAvailFlags[pSps->iSpsId]
&& pCtx->pAccessUnitList->uiAvailUnitsNum > 0) {
- PSps pNextUsedSps =
- pCtx->pAccessUnitList->pNalUnitsList[pCtx->pAccessUnitList->uiStartPos]->sNalData.sVclNal.sSliceHeaderExt.sSliceHeader.pSps;
- if (pNextUsedSps->iSpsId == pSps->iSpsId)
- return true;
+ int i = 0, iNum = (int32_t) pCtx->pAccessUnitList->uiAvailUnitsNum;
+ while (i < iNum) {
+ PNalUnit pNalUnit = pCtx->pAccessUnitList->pNalUnitsList[i];
+ if (pNalUnit->sNalData.sVclNal.bSliceHeaderExtFlag) { //ext data
+ PSps pNextUsedSps = pNalUnit->sNalData.sVclNal.sSliceHeaderExt.sSliceHeader.pSps;
+ if (pNextUsedSps->iSpsId == pSps->iSpsId)
+ return true;
+ }
+ ++i;
+ }
}
} else {
if (pSps->iMbWidth > 0 && pSps->iMbHeight > 0 && pCtx->bSpsAvailFlags[pSps->iSpsId]
&& pCtx->pAccessUnitList->uiAvailUnitsNum > 0) {
- PSps pNextUsedSps =
- pCtx->pAccessUnitList->pNalUnitsList[pCtx->pAccessUnitList->uiStartPos]->sNalData.sVclNal.sSliceHeaderExt.sSliceHeader.pSps;
- if (pNextUsedSps->iSpsId == pSps->iSpsId)
- return true;
+ int i = 0, iNum = (int32_t) pCtx->pAccessUnitList->uiAvailUnitsNum;
+ while (i < iNum) {
+ PNalUnit pNalUnit = pCtx->pAccessUnitList->pNalUnitsList[i];
+ if (!pNalUnit->sNalData.sVclNal.bSliceHeaderExtFlag) { //non-ext data
+ PSps pNextUsedSps = pNalUnit->sNalData.sVclNal.sSliceHeaderExt.sSliceHeader.pSps;
+ if (pNextUsedSps->iSpsId == pSps->iSpsId)
+ return true;
+ }
+ ++i;
+ }
}
}
return false;