Files
MXC_A59/lib/hx170dec/include/h264hwd_macroblock_layer.h

209 lines
5.8 KiB
C

/*------------------------------------------------------------------------------
-- --
-- This software is confidential and proprietary and may be used --
-- only as expressly authorized by a licensing agreement from --
-- --
-- Hantro Products Oy. --
-- --
-- (C) COPYRIGHT 2006 HANTRO PRODUCTS OY --
-- ALL RIGHTS RESERVED --
-- --
-- The entire notice above must be reproduced --
-- on all copies and should not be removed. --
-- --
--------------------------------------------------------------------------------
--
-- Abstract : Macroblock level stream decoding and macroblock reconstruction
--
--------------------------------------------------------------------------------
--
-- Version control information, please leave untouched.
--
-- $RCSfile: h264hwd_macroblock_layer.h,v $
-- $Date: 2008/03/13 12:48:06 $
-- $Revision: 1.1 $
--
------------------------------------------------------------------------------*/
#ifndef H264HWD_MACROBLOCK_LAYER_H
#define H264HWD_MACROBLOCK_LAYER_H
/*------------------------------------------------------------------------------
1. Include headers
------------------------------------------------------------------------------*/
#include "basetype.h"
#include "h264hwd_stream.h"
#include "h264hwd_slice_header.h"
/*------------------------------------------------------------------------------
2. Module defines
------------------------------------------------------------------------------*/
/* Macro to determine if a mb is an intra mb */
#define IS_INTRA_MB(a) ((a).mbType > 5)
/* Macro to determine if a mb is an I_PCM mb */
#define IS_I_PCM_MB(a) ((a).mbType == 31)
typedef enum mbType
{
P_Skip = 0,
P_L0_16x16 = 1,
P_L0_L0_16x8 = 2,
P_L0_L0_8x16 = 3,
P_8x8 = 4,
P_8x8ref0 = 5,
I_4x4 = 6,
I_16x16_0_0_0 = 7,
I_16x16_1_0_0 = 8,
I_16x16_2_0_0 = 9,
I_16x16_3_0_0 = 10,
I_16x16_0_1_0 = 11,
I_16x16_1_1_0 = 12,
I_16x16_2_1_0 = 13,
I_16x16_3_1_0 = 14,
I_16x16_0_2_0 = 15,
I_16x16_1_2_0 = 16,
I_16x16_2_2_0 = 17,
I_16x16_3_2_0 = 18,
I_16x16_0_0_1 = 19,
I_16x16_1_0_1 = 20,
I_16x16_2_0_1 = 21,
I_16x16_3_0_1 = 22,
I_16x16_0_1_1 = 23,
I_16x16_1_1_1 = 24,
I_16x16_2_1_1 = 25,
I_16x16_3_1_1 = 26,
I_16x16_0_2_1 = 27,
I_16x16_1_2_1 = 28,
I_16x16_2_2_1 = 29,
I_16x16_3_2_1 = 30,
I_PCM = 31
} mbType_e;
typedef enum subMbType
{
P_L0_8x8 = 0,
P_L0_8x4 = 1,
P_L0_4x8 = 2,
P_L0_4x4 = 3
} subMbType_e;
typedef enum mbPartMode
{
MB_P_16x16 = 0,
MB_P_16x8,
MB_P_8x16,
MB_P_8x8
} mbPartMode_e;
typedef enum subMbPartMode
{
MB_SP_8x8 = 0,
MB_SP_8x4,
MB_SP_4x8,
MB_SP_4x4
} subMbPartMode_e;
typedef enum mbPartPredMode
{
PRED_MODE_INTRA4x4 = 0,
PRED_MODE_INTRA16x16,
PRED_MODE_INTER
} mbPartPredMode_e;
/*------------------------------------------------------------------------------
3. Data types
------------------------------------------------------------------------------*/
typedef struct mv
{
i16 hor;
i16 ver;
} mv_t;
typedef struct mbPred
{
u32 prevIntra4x4PredModeFlag[16];
u32 remIntra4x4PredMode[16];
u32 intraChromaPredMode;
} mbPred_t;
typedef struct subMbPred
{
subMbType_e subMbType[4];
} subMbPred_t;
typedef struct
{
u16 rlc[468];
u8 totalCoeff[28];
} residual_t;
typedef struct macroblockLayer
{
/*u32 disableDeblockingFilterIdc; */
i32 filterOffsetA;
i32 filterOffsetB;
u32 disableDeblockingFilterIdc;
mbType_e mbType;
u32 codedBlockPattern;
i32 mbQpDelta;
mbPred_t mbPred;
subMbPred_t subMbPred;
residual_t residual;
} macroblockLayer_t;
typedef struct mbStorage
{
mbType_e mbType;
mbType_e mbType_asic;
u32 sliceId;
/*u32 disableDeblockingFilterIdc; */
/*i32 filterOffsetA; */
/*i32 filterOffsetB; */
u32 qpY;
/*i32 chromaQpIndexOffset; */
u8 totalCoeff[24];
u8 intra4x4PredMode[16];
u8 intra4x4PredMode_asic[16];
/* u32 refPic[4]; */
u8 refIdxL0[4];
u8 refID[4];
mv_t mv[16];
u32 decoded;
struct mbStorage *mbA;
struct mbStorage *mbB;
struct mbStorage *mbC;
struct mbStorage *mbD;
} mbStorage_t;
struct cabac_s;
/*------------------------------------------------------------------------------
4. Function prototypes
------------------------------------------------------------------------------*/
u32 h264bsdDecodeMacroblockLayerCavlc(strmData_t * pStrmData,
macroblockLayer_t * pMbLayer,
mbStorage_t * pMb,
const sliceHeader_t * pSliceHdr );
u32 h264bsdDecodeMacroblockLayerCabac(strmData_t * pStrmData,
macroblockLayer_t * pMbLayer,
mbStorage_t * pMb,
const sliceHeader_t * pSliceHdr,
struct cabac_s * pCabac );
u32 h264bsdNumSubMbPart(subMbType_e subMbType);
subMbPartMode_e h264bsdSubMbPartMode(subMbType_e subMbType);
u32 h264bsdPredModeIntra16x16(mbType_e mbType);
mbPartPredMode_e h264bsdMbPartPredMode(mbType_e mbType);
#endif /* #ifdef H264HWD_MACROBLOCK_LAYER_H */