shithub: openh264

ref: e3e5208509d0fdf51ef743c9f26ebea3379251c4
dir: /codec/decoder/core/inc/wels_common_basis.h/

View raw version
/*!
 * \copy
 *     Copyright (c)  2013, Cisco Systems
 *     All rights reserved.
 *
 *     Redistribution and use in source and binary forms, with or without
 *     modification, are permitted provided that the following conditions
 *     are met:
 *
 *        * Redistributions of source code must retain the above copyright
 *          notice, this list of conditions and the following disclaimer.
 *
 *        * Redistributions in binary form must reproduce the above copyright
 *          notice, this list of conditions and the following disclaimer in
 *          the documentation and/or other materials provided with the
 *          distribution.
 *
 *     THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 *     "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 *     LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
 *     FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
 *     COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
 *     INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
 *     BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 *     LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 *     CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
 *     LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
 *     ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 *     POSSIBILITY OF SUCH DAMAGE.
 *
 */

//wels_common_basis.h
#ifndef WELS_COMMON_BASIS_H__
#define WELS_COMMON_BASIS_H__

#include "typedefs.h"
#include "macros.h"

#include "wels_common_defs.h"

using namespace WelsCommon;

namespace WelsDec {

/*common use table*/
extern const uint8_t g_kuiScan8[24];
extern const uint8_t g_kuiLumaDcZigzagScan[16];
extern const uint8_t g_kuiChromaDcScan[4];
extern const uint8_t g_kMbNonZeroCountIdx[24];
extern const uint8_t g_kCacheNzcScanIdx[4*4+4+4+3];
extern const uint8_t g_kCache26ScanIdx[16];
extern const uint8_t g_kCache30ScanIdx[16];
extern const uint8_t g_kNonZeroScanIdxC[4];
/* Profile IDC */
typedef uint8_t		ProfileIdc;
enum {
PRO_BASELINE	= 66,
PRO_MAIN		= 77,
PRO_EXTENDED	= 88,
PRO_HIGH		= 100,
PRO_HIGH10		= 110,
PRO_HIGH422		= 122,
PRO_HIGH444		= 144,
PRO_CAVLC444	= 244,

PRO_SCALABLE_BASELINE	= 83,
PRO_SCALABLE_HIGH		= 86
};

/* Picture Size */
typedef struct TagPictureSize {
int32_t	iWidth;
int32_t iHeight;
} SPictureSize;


/* Position Offset structure */
typedef struct TagPosOffset {
int32_t	iLeftOffset;
int32_t	iTopOffset;
int32_t	iRightOffset;
int32_t	iBottomOffset;
} SPosOffset;

enum EMbPosition { //
MB_LEFT     = 0x01,	// A
MB_TOP      = 0x02,	// B
MB_TOPRIGHT = 0x04,	// C
MB_TOPLEFT	= 0x08,	// D,
MB_PRIVATE  = 0x10
};
/* MB Type & Sub-MB Type */
typedef int32_t MbType;
typedef int32_t SubMbType;

#define MB_TYPE_INTRA4x4       0x01
#define MB_TYPE_INTRA16x16     0x02
#define MB_TYPE_INTRA8x8       0x03
#define MB_TYPE_INTRA_PCM      0x04

#define MB_TYPE_INTRA_BL       0x05// I_BL new MB type

#define MB_TYPE_16x16          0x06
#define MB_TYPE_16x8           0x07
#define MB_TYPE_8x16           0x08
#define MB_TYPE_8x8            0x09
#define MB_TYPE_8x8_REF0       0x0a

#define SUB_MB_TYPE_8x8        0x0b
#define SUB_MB_TYPE_8x4        0x0c
#define SUB_MB_TYPE_4x8        0x0d
#define SUB_MB_TYPE_4x4        0x0e
#define MB_TYPE_SKIP           0x0f
#define MB_TYPE_DIRECT2        0x10
#define not_available		   0x20

#define IS_INTRA4x4(type) ( MB_TYPE_INTRA4x4 == (type) )
#define IS_INTRA16x16(type) ( MB_TYPE_INTRA16x16 == (type) )
#define IS_INTRA(type) ( (type) > 0 && (type) < 5 )
#define IS_INTER(type) ( (type) > 5 && (type) < 16 )

#define IS_I_BL(type) ( (type) == MB_TYPE_INTRA_BL )
#define IS_SUB8x8(type) (MB_TYPE_8x8 == (type) || MB_TYPE_8x8_REF0 == (type))

#define I16_LUMA_DC  1
#define I16_LUMA_AC  2
#define LUMA_DC_AC   3
#define CHROMA_DC    4
#define CHROMA_AC    5
#define CHROMA_DC_U  6
#define CHROMA_DC_V  7
#define CHROMA_AC_U  8
#define CHROMA_AC_V  9
#define LUMA_DC_AC_INTRA 10
#define LUMA_DC_AC_INTER 11
#define CHROMA_DC_U_INTER  12
#define CHROMA_DC_V_INTER  13
#define CHROMA_AC_U_INTER  14
#define CHROMA_AC_V_INTER  15

typedef struct TagReadBitsCache {
    uint32_t uiCache32Bit;
    uint8_t  uiRemainBits;
    uint8_t*  pBuf;
} SReadBitsCache;

#define SHIFT_BUFFER(pBitsCache)	{	pBitsCache->pBuf+=2; pBitsCache->uiRemainBits += 16; pBitsCache->uiCache32Bit |= (((pBitsCache->pBuf[2] << 8) | pBitsCache->pBuf[3]) << (32 - pBitsCache->uiRemainBits));	}
#define POP_BUFFER(pBitsCache, iCount)	{ pBitsCache->uiCache32Bit <<= iCount;	pBitsCache->uiRemainBits -= iCount;	}

static const uint8_t g_kuiZigzagScan[16] = { //4*4block residual zig-zag scan order
    0,  1,  4,  8,
    5,  2,  3,  6,
    9, 12, 13, 10,
    7, 11, 14, 15,
};


static inline void GetMbResProperty(int32_t * pMBproperty,int32_t* pResidualProperty,bool bCavlc)
{
 switch(*pResidualProperty)
  {
  case CHROMA_AC_U:
	  *pMBproperty = 1;
	  *pResidualProperty = bCavlc ? CHROMA_AC : CHROMA_AC_U;
	  break;
  case CHROMA_AC_V:
	  *pMBproperty = 2;
	  *pResidualProperty = bCavlc ? CHROMA_AC : CHROMA_AC_V;
	  break;
  case LUMA_DC_AC_INTRA:
	  *pMBproperty = 0;
	  *pResidualProperty = LUMA_DC_AC;
	  break;
  case CHROMA_DC_U:
      *pMBproperty = 1;
	  *pResidualProperty =  bCavlc ? CHROMA_DC : CHROMA_DC_U;
      break;
 case CHROMA_DC_V:
	  *pMBproperty = 2;
	  *pResidualProperty =  bCavlc ? CHROMA_DC : CHROMA_DC_V;
	  break;
  case I16_LUMA_AC:
	  *pMBproperty = 0;
	  break;
  case I16_LUMA_DC:
	  *pMBproperty = 0;
	  break;
  case LUMA_DC_AC_INTER:
	  *pMBproperty = 3;
      *pResidualProperty = LUMA_DC_AC;
	  break;
  case CHROMA_DC_U_INTER:
      *pMBproperty = 4;
	  *pResidualProperty =  bCavlc ? CHROMA_DC : CHROMA_DC_U;
      break;
  case CHROMA_DC_V_INTER:
	  *pMBproperty = 5;
	  *pResidualProperty =  bCavlc ? CHROMA_DC : CHROMA_DC_V;
	  break;
 case CHROMA_AC_U_INTER:
	  *pMBproperty = 4;
	  *pResidualProperty =  bCavlc ? CHROMA_AC : CHROMA_AC_U;
	  break;
 case CHROMA_AC_V_INTER:
	  *pMBproperty = 5;
	  *pResidualProperty =  bCavlc ?CHROMA_AC:CHROMA_AC_V;
	  break;
 }
  }

typedef struct TagI16PredInfo {
    int8_t iPredMode;
    int8_t iLeftAvail;
    int8_t iTopAvail;
    int8_t iLeftTopAvail;
} SI16PredInfo;
static const SI16PredInfo g_ksI16PredInfo[4] = {
    {I16_PRED_V, 0, 1, 0},
    {I16_PRED_H, 1, 0, 0},
    {         0, 0, 0, 0},
    {I16_PRED_P, 1, 1, 1},
};

static const SI16PredInfo g_ksChromaPredInfo[4] = {
    {       0, 0, 0, 0},
    {C_PRED_H, 1, 0, 0},
    {C_PRED_V, 0, 1, 0},
    {C_PRED_P, 1, 1, 1},
};


typedef struct TagI4PredInfo {
    int8_t iPredMode;
    int8_t iLeftAvail;
    int8_t iTopAvail;
    int8_t iLeftTopAvail;
    //	int8_t right_top_avail; //when right_top unavailable but top avail, we can pad the right-top with the rightmost pixel of top
} SI4PredInfo;
static const SI4PredInfo g_ksI4PredInfo[9] = {
    {  I4_PRED_V, 0, 1, 0},
    {  I4_PRED_H, 1, 0, 0},
    {          0, 0, 0, 0},
    {I4_PRED_DDL, 0, 1, 0},
    {I4_PRED_DDR, 1, 1, 1},
    { I4_PRED_VR, 1, 1, 1},
    { I4_PRED_HD, 1, 1, 1},
    { I4_PRED_VL, 0, 1, 0},
    { I4_PRED_HU, 1, 0, 0},
};

static const uint8_t g_kuiI16CbpTable[6] = {0, 16, 32, 15, 31, 47}; 


typedef struct TagPartMbInfo {
    MbType iType;
    int8_t iPartCount; //P_16*16, P_16*8, P_8*16, P_8*8 based on 8*8 block; P_8*4, P_4*8, P_4*4 based on 4*4 block
    int8_t iPartWidth; //based on 4*4 block
} SPartMbInfo;
static const SPartMbInfo g_ksInterMbTypeInfo[5] = {
    {MB_TYPE_16x16,    1, 4},
    {MB_TYPE_16x8,     2, 4},
    {MB_TYPE_8x16,     2, 2},
    {MB_TYPE_8x8,      4, 4},
    {MB_TYPE_8x8_REF0, 4, 4}, //ref0--ref_idx not present in bit-stream and default as 0
};
static const SPartMbInfo g_ksInterSubMbTypeInfo[4] = {
    {SUB_MB_TYPE_8x8, 1, 2},
    {SUB_MB_TYPE_8x4, 2, 2},
    {SUB_MB_TYPE_4x8, 2, 1},
    {SUB_MB_TYPE_4x4, 4, 1},
};

} // namespace WelsDec

#endif//WELS_COMMON_BASIS_H__