1*495ae853SAndroid Build Coastguard Worker /******************************************************************************
2*495ae853SAndroid Build Coastguard Worker *
3*495ae853SAndroid Build Coastguard Worker * Copyright (C) 2022 The Android Open Source Project
4*495ae853SAndroid Build Coastguard Worker *
5*495ae853SAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License");
6*495ae853SAndroid Build Coastguard Worker * you may not use this file except in compliance with the License.
7*495ae853SAndroid Build Coastguard Worker * You may obtain a copy of the License at:
8*495ae853SAndroid Build Coastguard Worker *
9*495ae853SAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0
10*495ae853SAndroid Build Coastguard Worker *
11*495ae853SAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software
12*495ae853SAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS,
13*495ae853SAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14*495ae853SAndroid Build Coastguard Worker * See the License for the specific language governing permissions and
15*495ae853SAndroid Build Coastguard Worker * limitations under the License.
16*495ae853SAndroid Build Coastguard Worker *
17*495ae853SAndroid Build Coastguard Worker *****************************************************************************
18*495ae853SAndroid Build Coastguard Worker * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
19*495ae853SAndroid Build Coastguard Worker */
20*495ae853SAndroid Build Coastguard Worker /**
21*495ae853SAndroid Build Coastguard Worker *******************************************************************************
22*495ae853SAndroid Build Coastguard Worker * @file
23*495ae853SAndroid Build Coastguard Worker * isvcd_cabac.c
24*495ae853SAndroid Build Coastguard Worker *
25*495ae853SAndroid Build Coastguard Worker * @brief
26*495ae853SAndroid Build Coastguard Worker * This file contains Binary decoding routines.
27*495ae853SAndroid Build Coastguard Worker *
28*495ae853SAndroid Build Coastguard Worker * @author
29*495ae853SAndroid Build Coastguard Worker * Kishore
30*495ae853SAndroid Build Coastguard Worker *
31*495ae853SAndroid Build Coastguard Worker * @par List of Functions:
32*495ae853SAndroid Build Coastguard Worker * - isvcd_init_cabac_contexts()
33*495ae853SAndroid Build Coastguard Worker *
34*495ae853SAndroid Build Coastguard Worker * @remarks
35*495ae853SAndroid Build Coastguard Worker * None
36*495ae853SAndroid Build Coastguard Worker *
37*495ae853SAndroid Build Coastguard Worker *******************************************************************************
38*495ae853SAndroid Build Coastguard Worker */
39*495ae853SAndroid Build Coastguard Worker
40*495ae853SAndroid Build Coastguard Worker #include <string.h>
41*495ae853SAndroid Build Coastguard Worker #include "ih264_typedefs.h"
42*495ae853SAndroid Build Coastguard Worker #include "ih264_macros.h"
43*495ae853SAndroid Build Coastguard Worker #include "ih264_platform_macros.h"
44*495ae853SAndroid Build Coastguard Worker #include "isvcd_structs.h"
45*495ae853SAndroid Build Coastguard Worker #include "ih264d_cabac.h"
46*495ae853SAndroid Build Coastguard Worker #include "isvcd_cabac.h"
47*495ae853SAndroid Build Coastguard Worker #include "ih264d_bitstrm.h"
48*495ae853SAndroid Build Coastguard Worker #include "ih264d_error_handler.h"
49*495ae853SAndroid Build Coastguard Worker #include "ih264d_defs.h"
50*495ae853SAndroid Build Coastguard Worker #include "ih264d_debug.h"
51*495ae853SAndroid Build Coastguard Worker #include "ih264d_tables.h"
52*495ae853SAndroid Build Coastguard Worker #include "isvcd_tables.h"
53*495ae853SAndroid Build Coastguard Worker #include "ih264d_parse_cabac.h"
54*495ae853SAndroid Build Coastguard Worker #include "ih264d_tables.h"
55*495ae853SAndroid Build Coastguard Worker
56*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
57*495ae853SAndroid Build Coastguard Worker /* */
58*495ae853SAndroid Build Coastguard Worker /* Function Name : isvcd_init_cabac_contexts */
59*495ae853SAndroid Build Coastguard Worker /* */
60*495ae853SAndroid Build Coastguard Worker /* Description : This function initializes the cabac contexts */
61*495ae853SAndroid Build Coastguard Worker /* depending upon slice type and Init_Idc value. */
62*495ae853SAndroid Build Coastguard Worker /* Inputs : ps_dec, slice type */
63*495ae853SAndroid Build Coastguard Worker /* Globals : <Does it use any global variables?> */
64*495ae853SAndroid Build Coastguard Worker /* Outputs : */
65*495ae853SAndroid Build Coastguard Worker /* Returns : void */
66*495ae853SAndroid Build Coastguard Worker /* */
67*495ae853SAndroid Build Coastguard Worker /* Issues : none */
68*495ae853SAndroid Build Coastguard Worker /* */
69*495ae853SAndroid Build Coastguard Worker /* Revision History: */
70*495ae853SAndroid Build Coastguard Worker /* */
71*495ae853SAndroid Build Coastguard Worker /* DD MM YYYY Author(s) Changes (Describe the changes made) */
72*495ae853SAndroid Build Coastguard Worker /* 06 09 2021 Kishore Draft */
73*495ae853SAndroid Build Coastguard Worker /* */
74*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
75*495ae853SAndroid Build Coastguard Worker
isvcd_init_cabac_contexts(UWORD8 u1_slice_type,dec_struct_t * ps_dec)76*495ae853SAndroid Build Coastguard Worker void isvcd_init_cabac_contexts(UWORD8 u1_slice_type, dec_struct_t *ps_dec)
77*495ae853SAndroid Build Coastguard Worker {
78*495ae853SAndroid Build Coastguard Worker bin_ctxt_model_t *p_cabac_ctxt_table_t = ps_dec->p_cabac_ctxt_table_t;
79*495ae853SAndroid Build Coastguard Worker UWORD8 u1_qp_y = ps_dec->ps_cur_slice->u1_slice_qp;
80*495ae853SAndroid Build Coastguard Worker UWORD8 u1_cabac_init_Idc = 0;
81*495ae853SAndroid Build Coastguard Worker
82*495ae853SAndroid Build Coastguard Worker if(I_SLICE != u1_slice_type)
83*495ae853SAndroid Build Coastguard Worker {
84*495ae853SAndroid Build Coastguard Worker u1_cabac_init_Idc = ps_dec->ps_cur_slice->u1_cabac_init_idc;
85*495ae853SAndroid Build Coastguard Worker }
86*495ae853SAndroid Build Coastguard Worker
87*495ae853SAndroid Build Coastguard Worker {
88*495ae853SAndroid Build Coastguard Worker /* MAKING ps_dec->p_ctxt_inc_mb_map a scratch buffer */
89*495ae853SAndroid Build Coastguard Worker /* 0th entry of CtxtIncMbMap will be always be containing default values
90*495ae853SAndroid Build Coastguard Worker for CABAC context representing MB not available */
91*495ae853SAndroid Build Coastguard Worker ctxt_inc_mb_info_t *p_DefCtxt = ps_dec->p_ctxt_inc_mb_map - 1;
92*495ae853SAndroid Build Coastguard Worker UWORD8 *pu1_temp;
93*495ae853SAndroid Build Coastguard Worker WORD8 i;
94*495ae853SAndroid Build Coastguard Worker p_DefCtxt->u1_mb_type = CAB_SKIP;
95*495ae853SAndroid Build Coastguard Worker p_DefCtxt->u1_cbp = 0x0f;
96*495ae853SAndroid Build Coastguard Worker p_DefCtxt->u1_intra_chroma_pred_mode = 0;
97*495ae853SAndroid Build Coastguard Worker p_DefCtxt->u1_yuv_dc_csbp = 0x7;
98*495ae853SAndroid Build Coastguard Worker p_DefCtxt->u1_transform8x8_ctxt = 0;
99*495ae853SAndroid Build Coastguard Worker
100*495ae853SAndroid Build Coastguard Worker pu1_temp = (UWORD8 *) p_DefCtxt->i1_ref_idx;
101*495ae853SAndroid Build Coastguard Worker for(i = 0; i < 4; i++, pu1_temp++) (*pu1_temp) = 0;
102*495ae853SAndroid Build Coastguard Worker pu1_temp = (UWORD8 *) p_DefCtxt->u1_mv;
103*495ae853SAndroid Build Coastguard Worker for(i = 0; i < 16; i++, pu1_temp++) (*pu1_temp) = 0;
104*495ae853SAndroid Build Coastguard Worker ps_dec->ps_def_ctxt_mb_info = p_DefCtxt;
105*495ae853SAndroid Build Coastguard Worker }
106*495ae853SAndroid Build Coastguard Worker
107*495ae853SAndroid Build Coastguard Worker if(u1_slice_type == I_SLICE)
108*495ae853SAndroid Build Coastguard Worker {
109*495ae853SAndroid Build Coastguard Worker u1_cabac_init_Idc = 3;
110*495ae853SAndroid Build Coastguard Worker ps_dec->p_mb_type_t = p_cabac_ctxt_table_t + MB_TYPE_I_SLICE;
111*495ae853SAndroid Build Coastguard Worker }
112*495ae853SAndroid Build Coastguard Worker else if(u1_slice_type == P_SLICE)
113*495ae853SAndroid Build Coastguard Worker {
114*495ae853SAndroid Build Coastguard Worker ps_dec->p_mb_type_t = p_cabac_ctxt_table_t + MB_TYPE_P_SLICE;
115*495ae853SAndroid Build Coastguard Worker ps_dec->p_mb_skip_flag_t = p_cabac_ctxt_table_t + MB_SKIP_FLAG_P_SLICE;
116*495ae853SAndroid Build Coastguard Worker ps_dec->p_sub_mb_type_t = p_cabac_ctxt_table_t + SUB_MB_TYPE_P_SLICE;
117*495ae853SAndroid Build Coastguard Worker }
118*495ae853SAndroid Build Coastguard Worker else if(u1_slice_type == B_SLICE)
119*495ae853SAndroid Build Coastguard Worker {
120*495ae853SAndroid Build Coastguard Worker ps_dec->p_mb_type_t = p_cabac_ctxt_table_t + MB_TYPE_B_SLICE;
121*495ae853SAndroid Build Coastguard Worker ps_dec->p_mb_skip_flag_t = p_cabac_ctxt_table_t + MB_SKIP_FLAG_B_SLICE;
122*495ae853SAndroid Build Coastguard Worker ps_dec->p_sub_mb_type_t = p_cabac_ctxt_table_t + SUB_MB_TYPE_B_SLICE;
123*495ae853SAndroid Build Coastguard Worker }
124*495ae853SAndroid Build Coastguard Worker {
125*495ae853SAndroid Build Coastguard Worker bin_ctxt_model_t *p_cabac_ctxt_table_t_tmp = p_cabac_ctxt_table_t;
126*495ae853SAndroid Build Coastguard Worker if(ps_dec->ps_cur_slice->u1_field_pic_flag)
127*495ae853SAndroid Build Coastguard Worker {
128*495ae853SAndroid Build Coastguard Worker p_cabac_ctxt_table_t_tmp += SIGNIFICANT_COEFF_FLAG_FLD;
129*495ae853SAndroid Build Coastguard Worker }
130*495ae853SAndroid Build Coastguard Worker else
131*495ae853SAndroid Build Coastguard Worker {
132*495ae853SAndroid Build Coastguard Worker p_cabac_ctxt_table_t_tmp += SIGNIFICANT_COEFF_FLAG_FRAME;
133*495ae853SAndroid Build Coastguard Worker }
134*495ae853SAndroid Build Coastguard Worker {
135*495ae853SAndroid Build Coastguard Worker bin_ctxt_model_t **p_significant_coeff_flag_t = ps_dec->p_significant_coeff_flag_t;
136*495ae853SAndroid Build Coastguard Worker p_significant_coeff_flag_t[0] = p_cabac_ctxt_table_t_tmp + SIG_COEFF_CTXT_CAT_0_OFFSET;
137*495ae853SAndroid Build Coastguard Worker p_significant_coeff_flag_t[1] = p_cabac_ctxt_table_t_tmp + SIG_COEFF_CTXT_CAT_1_OFFSET;
138*495ae853SAndroid Build Coastguard Worker p_significant_coeff_flag_t[2] = p_cabac_ctxt_table_t_tmp + SIG_COEFF_CTXT_CAT_2_OFFSET;
139*495ae853SAndroid Build Coastguard Worker p_significant_coeff_flag_t[3] = p_cabac_ctxt_table_t_tmp + SIG_COEFF_CTXT_CAT_3_OFFSET;
140*495ae853SAndroid Build Coastguard Worker p_significant_coeff_flag_t[4] = p_cabac_ctxt_table_t_tmp + SIG_COEFF_CTXT_CAT_4_OFFSET;
141*495ae853SAndroid Build Coastguard Worker
142*495ae853SAndroid Build Coastguard Worker p_significant_coeff_flag_t[5] = p_cabac_ctxt_table_t_tmp + SIG_COEFF_CTXT_CAT_5_OFFSET;
143*495ae853SAndroid Build Coastguard Worker }
144*495ae853SAndroid Build Coastguard Worker }
145*495ae853SAndroid Build Coastguard Worker
146*495ae853SAndroid Build Coastguard Worker memcpy(p_cabac_ctxt_table_t, gau1_isvcd_cabac_ctxt_init_table[u1_cabac_init_Idc][u1_qp_y],
147*495ae853SAndroid Build Coastguard Worker NUM_CABAC_CTXTS_SVC * sizeof(bin_ctxt_model_t));
148*495ae853SAndroid Build Coastguard Worker }
149