1*c83a76b0SSuyog Pawar /****************************************************************************** 2*c83a76b0SSuyog Pawar * 3*c83a76b0SSuyog Pawar * Copyright (C) 2012 Ittiam Systems Pvt Ltd, Bangalore 4*c83a76b0SSuyog Pawar * 5*c83a76b0SSuyog Pawar * Licensed under the Apache License, Version 2.0 (the "License"); 6*c83a76b0SSuyog Pawar * you may not use this file except in compliance with the License. 7*c83a76b0SSuyog Pawar * You may obtain a copy of the License at: 8*c83a76b0SSuyog Pawar * 9*c83a76b0SSuyog Pawar * http://www.apache.org/licenses/LICENSE-2.0 10*c83a76b0SSuyog Pawar * 11*c83a76b0SSuyog Pawar * Unless required by applicable law or agreed to in writing, software 12*c83a76b0SSuyog Pawar * distributed under the License is distributed on an "AS IS" BASIS, 13*c83a76b0SSuyog Pawar * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14*c83a76b0SSuyog Pawar * See the License for the specific language governing permissions and 15*c83a76b0SSuyog Pawar * limitations under the License. 16*c83a76b0SSuyog Pawar * 17*c83a76b0SSuyog Pawar ******************************************************************************/ 18*c83a76b0SSuyog Pawar 19*c83a76b0SSuyog Pawar /** 20*c83a76b0SSuyog Pawar ****************************************************************************** 21*c83a76b0SSuyog Pawar * @file ihevc_cabac_tables.h 22*c83a76b0SSuyog Pawar * 23*c83a76b0SSuyog Pawar * @brief 24*c83a76b0SSuyog Pawar * This file contains enumerations, macros and extern declarations of HEVC 25*c83a76b0SSuyog Pawar * cabac tables 26*c83a76b0SSuyog Pawar * 27*c83a76b0SSuyog Pawar * @author 28*c83a76b0SSuyog Pawar * Ittiam 29*c83a76b0SSuyog Pawar ****************************************************************************** 30*c83a76b0SSuyog Pawar */ 31*c83a76b0SSuyog Pawar 32*c83a76b0SSuyog Pawar #ifndef _IHEVC_CABAC_TABLES_H_ 33*c83a76b0SSuyog Pawar #define _IHEVC_CABAC_TABLES_H_ 34*c83a76b0SSuyog Pawar 35*c83a76b0SSuyog Pawar /*****************************************************************************/ 36*c83a76b0SSuyog Pawar /* Constant Macros */ 37*c83a76b0SSuyog Pawar /*****************************************************************************/ 38*c83a76b0SSuyog Pawar 39*c83a76b0SSuyog Pawar /** 40*c83a76b0SSuyog Pawar ****************************************************************************** 41*c83a76b0SSuyog Pawar * @brief maximum range of cabac_init_idc (0-2) 42*c83a76b0SSuyog Pawar ****************************************************************************** 43*c83a76b0SSuyog Pawar */ 44*c83a76b0SSuyog Pawar #define IHEVC_NUM_CAB_IDC 3 45*c83a76b0SSuyog Pawar 46*c83a76b0SSuyog Pawar /** 47*c83a76b0SSuyog Pawar ****************************************************************************** 48*c83a76b0SSuyog Pawar * @brief max range of qps in HEVC (0-51) 49*c83a76b0SSuyog Pawar ****************************************************************************** 50*c83a76b0SSuyog Pawar */ 51*c83a76b0SSuyog Pawar #define IHEVC_MAX_QP 52 52*c83a76b0SSuyog Pawar 53*c83a76b0SSuyog Pawar 54*c83a76b0SSuyog Pawar /*****************************************************************************/ 55*c83a76b0SSuyog Pawar /* Enums */ 56*c83a76b0SSuyog Pawar /*****************************************************************************/ 57*c83a76b0SSuyog Pawar 58*c83a76b0SSuyog Pawar /** 59*c83a76b0SSuyog Pawar ***************************************************************************** 60*c83a76b0SSuyog Pawar * @brief start offsets of cabac contexts for various syntax elements 61*c83a76b0SSuyog Pawar * 62*c83a76b0SSuyog Pawar * @remarks Init ContextModel generation and these offsets are tightly coupled 63*c83a76b0SSuyog Pawar See the cabac table generation utility for these offsets 64*c83a76b0SSuyog Pawar ***************************************************************************** 65*c83a76b0SSuyog Pawar */ 66*c83a76b0SSuyog Pawar typedef enum 67*c83a76b0SSuyog Pawar { 68*c83a76b0SSuyog Pawar IHEVC_CAB_SAO_MERGE = 0, 69*c83a76b0SSuyog Pawar IHEVC_CAB_SAO_TYPE = IHEVC_CAB_SAO_MERGE + 1, 70*c83a76b0SSuyog Pawar IHEVC_CAB_SPLIT_CU_FLAG = IHEVC_CAB_SAO_TYPE + 1, 71*c83a76b0SSuyog Pawar IHEVC_CAB_CU_TQ_BYPASS_FLAG = IHEVC_CAB_SPLIT_CU_FLAG + 3, 72*c83a76b0SSuyog Pawar IHEVC_CAB_SKIP_FLAG = IHEVC_CAB_CU_TQ_BYPASS_FLAG + 1, 73*c83a76b0SSuyog Pawar IHEVC_CAB_QP_DELTA_ABS = IHEVC_CAB_SKIP_FLAG + 3, 74*c83a76b0SSuyog Pawar IHEVC_CAB_PRED_MODE = IHEVC_CAB_QP_DELTA_ABS + 2, 75*c83a76b0SSuyog Pawar IHEVC_CAB_PART_MODE = IHEVC_CAB_PRED_MODE + 1, 76*c83a76b0SSuyog Pawar IHEVC_CAB_INTRA_LUMA_PRED_FLAG = IHEVC_CAB_PART_MODE + 4, 77*c83a76b0SSuyog Pawar IHEVC_CAB_CHROMA_PRED_MODE = IHEVC_CAB_INTRA_LUMA_PRED_FLAG + 1, 78*c83a76b0SSuyog Pawar IHEVC_CAB_MERGE_FLAG_EXT = IHEVC_CAB_CHROMA_PRED_MODE + 1, 79*c83a76b0SSuyog Pawar IHEVC_CAB_MERGE_IDX_EXT = IHEVC_CAB_MERGE_FLAG_EXT + 1, 80*c83a76b0SSuyog Pawar IHEVC_CAB_INTER_PRED_IDC = IHEVC_CAB_MERGE_IDX_EXT + 1, 81*c83a76b0SSuyog Pawar IHEVC_CAB_INTER_REF_IDX = IHEVC_CAB_INTER_PRED_IDC + 5, 82*c83a76b0SSuyog Pawar IHEVC_CAB_MVD_GRT0 = IHEVC_CAB_INTER_REF_IDX + 2, 83*c83a76b0SSuyog Pawar IHEVC_CAB_MVD_GRT1 = IHEVC_CAB_MVD_GRT0 + 1, 84*c83a76b0SSuyog Pawar IHEVC_CAB_MVP_L0L1 = IHEVC_CAB_MVD_GRT1 + 1, 85*c83a76b0SSuyog Pawar IHEVC_CAB_NORES_IDX = IHEVC_CAB_MVP_L0L1 + 1, 86*c83a76b0SSuyog Pawar IHEVC_CAB_SPLIT_TFM = IHEVC_CAB_NORES_IDX + 1, 87*c83a76b0SSuyog Pawar IHEVC_CAB_CBF_LUMA_IDX = IHEVC_CAB_SPLIT_TFM + 3, 88*c83a76b0SSuyog Pawar IHEVC_CAB_CBCR_IDX = IHEVC_CAB_CBF_LUMA_IDX + 2, 89*c83a76b0SSuyog Pawar IHEVC_CAB_TFM_SKIP0 = IHEVC_CAB_CBCR_IDX + 4, 90*c83a76b0SSuyog Pawar IHEVC_CAB_TFM_SKIP12 = IHEVC_CAB_TFM_SKIP0 + 1, 91*c83a76b0SSuyog Pawar IHEVC_CAB_COEFFX_PREFIX = IHEVC_CAB_TFM_SKIP12 + 1, 92*c83a76b0SSuyog Pawar IHEVC_CAB_COEFFY_PREFIX = IHEVC_CAB_COEFFX_PREFIX + 18, 93*c83a76b0SSuyog Pawar IHEVC_CAB_CODED_SUBLK_IDX = IHEVC_CAB_COEFFY_PREFIX + 18, 94*c83a76b0SSuyog Pawar IHEVC_CAB_COEFF_FLAG = IHEVC_CAB_CODED_SUBLK_IDX + 4, 95*c83a76b0SSuyog Pawar IHEVC_CAB_COEFABS_GRTR1_FLAG = IHEVC_CAB_COEFF_FLAG + 42, 96*c83a76b0SSuyog Pawar IHEVC_CAB_COEFABS_GRTR2_FLAG = IHEVC_CAB_COEFABS_GRTR1_FLAG + 24, 97*c83a76b0SSuyog Pawar IHEVC_CAB_CTXT_END = IHEVC_CAB_COEFABS_GRTR2_FLAG + 6 98*c83a76b0SSuyog Pawar }IHEVC_CABAC_CTXT_OFFSETS; 99*c83a76b0SSuyog Pawar 100*c83a76b0SSuyog Pawar 101*c83a76b0SSuyog Pawar /*****************************************************************************/ 102*c83a76b0SSuyog Pawar /* Extern global declarations */ 103*c83a76b0SSuyog Pawar /*****************************************************************************/ 104*c83a76b0SSuyog Pawar 105*c83a76b0SSuyog Pawar /** 106*c83a76b0SSuyog Pawar ****************************************************************************** 107*c83a76b0SSuyog Pawar * @brief Table for rangeTabLPS depending on pStateIdx and qCodIRangeIdx 108*c83a76b0SSuyog Pawar * input : pStateIdx(0-63) and qCodIRangeIdx(0-3) [(Range >> 6) & 0x3] 109*c83a76b0SSuyog Pawar * output : RLps 110*c83a76b0SSuyog Pawar * 111*c83a76b0SSuyog Pawar * @remarks See Table 9-40 of HEVC spec for rangeTabLPS 112*c83a76b0SSuyog Pawar ******************************************************************************* 113*c83a76b0SSuyog Pawar */ 114*c83a76b0SSuyog Pawar extern const UWORD8 gau1_ihevc_cabac_rlps[64][4]; 115*c83a76b0SSuyog Pawar 116*c83a76b0SSuyog Pawar 117*c83a76b0SSuyog Pawar /** 118*c83a76b0SSuyog Pawar ****************************************************************************** 119*c83a76b0SSuyog Pawar * @brief probaility+MPS state transition tables based on cur State and bin 120*c83a76b0SSuyog Pawar * input : curpState[bits7-2] | curMPS[bit1] | decodedBin[bit0] 121*c83a76b0SSuyog Pawar * output : nextpState[bits6-1] | nextMPS[bit0] 122*c83a76b0SSuyog Pawar * @remarks Modified form of Table-9-41 State Transition table in HEVC spec 123*c83a76b0SSuyog Pawar ****************************************************************************** 124*c83a76b0SSuyog Pawar */ 125*c83a76b0SSuyog Pawar extern const UWORD8 gau1_ihevc_next_state[128*2]; 126*c83a76b0SSuyog Pawar 127*c83a76b0SSuyog Pawar /** 128*c83a76b0SSuyog Pawar ****************************************************************************** 129*c83a76b0SSuyog Pawar * @brief Init context tables for all combinations of qp and cabac_init_idc 130*c83a76b0SSuyog Pawar * @remarks Packing format MPS in lsb and pState in bits[1-6] 131*c83a76b0SSuyog Pawar ****************************************************************************** 132*c83a76b0SSuyog Pawar */ 133*c83a76b0SSuyog Pawar extern const UWORD8 gau1_ihevc_cab_ctxts[IHEVC_NUM_CAB_IDC][IHEVC_MAX_QP][IHEVC_CAB_CTXT_END]; 134*c83a76b0SSuyog Pawar 135*c83a76b0SSuyog Pawar 136*c83a76b0SSuyog Pawar 137*c83a76b0SSuyog Pawar #endif /* _IHEVC_CABAC_TABLES_H_ */ 138