xref: /aosp_15_r20/external/libavc/encoder/svc/isvce_cabac_init.c (revision 495ae853bb871d1e5a258cb02c2cc13cde8ddb9a)
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 *******************************************************************************
23*495ae853SAndroid Build Coastguard Worker * @file
24*495ae853SAndroid Build Coastguard Worker * isvce_cabac_init.c
25*495ae853SAndroid Build Coastguard Worker *
26*495ae853SAndroid Build Coastguard Worker * @brief
27*495ae853SAndroid Build Coastguard Worker *  Contains all initialization functions for cabac contexts
28*495ae853SAndroid Build Coastguard Worker *
29*495ae853SAndroid Build Coastguard Worker * @author
30*495ae853SAndroid Build Coastguard Worker *  Doney Alex
31*495ae853SAndroid Build Coastguard Worker *
32*495ae853SAndroid Build Coastguard Worker * @par List of Functions:
33*495ae853SAndroid Build Coastguard Worker *
34*495ae853SAndroid Build Coastguard Worker *
35*495ae853SAndroid Build Coastguard Worker * @remarks
36*495ae853SAndroid Build Coastguard Worker *  None
37*495ae853SAndroid Build Coastguard Worker *
38*495ae853SAndroid Build Coastguard Worker *******************************************************************************
39*495ae853SAndroid Build Coastguard Worker */
40*495ae853SAndroid Build Coastguard Worker 
41*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
42*495ae853SAndroid Build Coastguard Worker /* File Includes                                                             */
43*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
44*495ae853SAndroid Build Coastguard Worker 
45*495ae853SAndroid Build Coastguard Worker /* System include files */
46*495ae853SAndroid Build Coastguard Worker #include <stdio.h>
47*495ae853SAndroid Build Coastguard Worker #include <stddef.h>
48*495ae853SAndroid Build Coastguard Worker #include <stdlib.h>
49*495ae853SAndroid Build Coastguard Worker #include <string.h>
50*495ae853SAndroid Build Coastguard Worker #include <limits.h>
51*495ae853SAndroid Build Coastguard Worker #include <assert.h>
52*495ae853SAndroid Build Coastguard Worker 
53*495ae853SAndroid Build Coastguard Worker /* User include files */
54*495ae853SAndroid Build Coastguard Worker #include "ih264_typedefs.h"
55*495ae853SAndroid Build Coastguard Worker #include "iv2.h"
56*495ae853SAndroid Build Coastguard Worker #include "ive2.h"
57*495ae853SAndroid Build Coastguard Worker #include "isvc_defs.h"
58*495ae853SAndroid Build Coastguard Worker #include "ih264_debug.h"
59*495ae853SAndroid Build Coastguard Worker #include "ime_distortion_metrics.h"
60*495ae853SAndroid Build Coastguard Worker #include "ime_defs.h"
61*495ae853SAndroid Build Coastguard Worker #include "ime_structs.h"
62*495ae853SAndroid Build Coastguard Worker #include "ih264_error.h"
63*495ae853SAndroid Build Coastguard Worker #include "isvc_structs.h"
64*495ae853SAndroid Build Coastguard Worker #include "isvc_trans_quant_itrans_iquant.h"
65*495ae853SAndroid Build Coastguard Worker #include "isvc_inter_pred_filters.h"
66*495ae853SAndroid Build Coastguard Worker #include "isvc_mem_fns.h"
67*495ae853SAndroid Build Coastguard Worker #include "ih264_padding.h"
68*495ae853SAndroid Build Coastguard Worker #include "ih264_intra_pred_filters.h"
69*495ae853SAndroid Build Coastguard Worker #include "ih264_deblk_edge_filters.h"
70*495ae853SAndroid Build Coastguard Worker #include "ih264_platform_macros.h"
71*495ae853SAndroid Build Coastguard Worker #include "isvc_macros.h"
72*495ae853SAndroid Build Coastguard Worker #include "ih264_buf_mgr.h"
73*495ae853SAndroid Build Coastguard Worker #include "ih264e_error.h"
74*495ae853SAndroid Build Coastguard Worker #include "ih264e_bitstream.h"
75*495ae853SAndroid Build Coastguard Worker #include "isvc_common_tables.h"
76*495ae853SAndroid Build Coastguard Worker #include "isvc_cabac_tables.h"
77*495ae853SAndroid Build Coastguard Worker #include "ih264_list.h"
78*495ae853SAndroid Build Coastguard Worker #include "isvce_defs.h"
79*495ae853SAndroid Build Coastguard Worker #include "irc_cntrl_param.h"
80*495ae853SAndroid Build Coastguard Worker #include "irc_frame_info_collector.h"
81*495ae853SAndroid Build Coastguard Worker #include "isvce_rate_control.h"
82*495ae853SAndroid Build Coastguard Worker #include "isvce_cabac_structs.h"
83*495ae853SAndroid Build Coastguard Worker #include "isvce_structs.h"
84*495ae853SAndroid Build Coastguard Worker #include "isvce_cabac.h"
85*495ae853SAndroid Build Coastguard Worker #include "isvce_process.h"
86*495ae853SAndroid Build Coastguard Worker #include "ithread.h"
87*495ae853SAndroid Build Coastguard Worker #include "isvce_encode_header.h"
88*495ae853SAndroid Build Coastguard Worker #include "isvce_globals.h"
89*495ae853SAndroid Build Coastguard Worker #include "ih264e_config.h"
90*495ae853SAndroid Build Coastguard Worker #include "ih264e_trace.h"
91*495ae853SAndroid Build Coastguard Worker #include "ih264e_statistics.h"
92*495ae853SAndroid Build Coastguard Worker #include "ih264_cavlc_tables.h"
93*495ae853SAndroid Build Coastguard Worker #include "isvce_deblk.h"
94*495ae853SAndroid Build Coastguard Worker #include "isvce_me.h"
95*495ae853SAndroid Build Coastguard Worker #include "ih264e_debug.h"
96*495ae853SAndroid Build Coastguard Worker #include "ih264e_master.h"
97*495ae853SAndroid Build Coastguard Worker #include "isvce_utils.h"
98*495ae853SAndroid Build Coastguard Worker #include "irc_mem_req_and_acq.h"
99*495ae853SAndroid Build Coastguard Worker #include "irc_rate_control_api.h"
100*495ae853SAndroid Build Coastguard Worker #include "ih264e_platform_macros.h"
101*495ae853SAndroid Build Coastguard Worker #include "ime_statistics.h"
102*495ae853SAndroid Build Coastguard Worker 
103*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
104*495ae853SAndroid Build Coastguard Worker /*  Function definitions .                                                   */
105*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
106*495ae853SAndroid Build Coastguard Worker 
107*495ae853SAndroid Build Coastguard Worker /**
108*495ae853SAndroid Build Coastguard Worker  *******************************************************************************
109*495ae853SAndroid Build Coastguard Worker  *
110*495ae853SAndroid Build Coastguard Worker  * @brief
111*495ae853SAndroid Build Coastguard Worker  * Initialize cabac encoding environment
112*495ae853SAndroid Build Coastguard Worker  *
113*495ae853SAndroid Build Coastguard Worker  * @param[in] ps_cab_enc_env
114*495ae853SAndroid Build Coastguard Worker  *  Pointer to encoding_envirnoment_t structure
115*495ae853SAndroid Build Coastguard Worker  *
116*495ae853SAndroid Build Coastguard Worker  * @returns
117*495ae853SAndroid Build Coastguard Worker  *
118*495ae853SAndroid Build Coastguard Worker  * @remarks
119*495ae853SAndroid Build Coastguard Worker  *  None
120*495ae853SAndroid Build Coastguard Worker  *
121*495ae853SAndroid Build Coastguard Worker  *******************************************************************************
122*495ae853SAndroid Build Coastguard Worker  */
isvce_init_cabac_enc_envirnoment(encoding_envirnoment_t * ps_cab_enc_env)123*495ae853SAndroid Build Coastguard Worker static void isvce_init_cabac_enc_envirnoment(encoding_envirnoment_t *ps_cab_enc_env)
124*495ae853SAndroid Build Coastguard Worker {
125*495ae853SAndroid Build Coastguard Worker     ps_cab_enc_env->u4_code_int_low = 0;
126*495ae853SAndroid Build Coastguard Worker     ps_cab_enc_env->u4_code_int_range = 0x1fe;
127*495ae853SAndroid Build Coastguard Worker     ps_cab_enc_env->u4_out_standing_bytes = 0;
128*495ae853SAndroid Build Coastguard Worker     ps_cab_enc_env->u4_bits_gen = 0;
129*495ae853SAndroid Build Coastguard Worker }
130*495ae853SAndroid Build Coastguard Worker 
131*495ae853SAndroid Build Coastguard Worker /**
132*495ae853SAndroid Build Coastguard Worker  *******************************************************************************
133*495ae853SAndroid Build Coastguard Worker  *
134*495ae853SAndroid Build Coastguard Worker  * @brief
135*495ae853SAndroid Build Coastguard Worker  * Initialize default context values and pointers (Called once at the beginning
136*495ae853SAndroid Build Coastguard Worker  *of encoding).
137*495ae853SAndroid Build Coastguard Worker  *
138*495ae853SAndroid Build Coastguard Worker  * @param[in] ps_ent_ctxt
139*495ae853SAndroid Build Coastguard Worker  *  Pointer to entropy context structure
140*495ae853SAndroid Build Coastguard Worker  *
141*495ae853SAndroid Build Coastguard Worker  * @returns
142*495ae853SAndroid Build Coastguard Worker  *
143*495ae853SAndroid Build Coastguard Worker  * @remarks
144*495ae853SAndroid Build Coastguard Worker  *  None
145*495ae853SAndroid Build Coastguard Worker  *
146*495ae853SAndroid Build Coastguard Worker  *******************************************************************************
147*495ae853SAndroid Build Coastguard Worker  */
isvce_init_cabac_table(isvce_entropy_ctxt_t * ps_ent_ctxt)148*495ae853SAndroid Build Coastguard Worker void isvce_init_cabac_table(isvce_entropy_ctxt_t *ps_ent_ctxt)
149*495ae853SAndroid Build Coastguard Worker {
150*495ae853SAndroid Build Coastguard Worker     /* CABAC context */
151*495ae853SAndroid Build Coastguard Worker     isvce_cabac_ctxt_t *ps_cabac_ctxt = ps_ent_ctxt->ps_cabac;
152*495ae853SAndroid Build Coastguard Worker     ps_cabac_ctxt->ps_mb_map_ctxt_inc = ps_cabac_ctxt->ps_mb_map_ctxt_inc_base + 1;
153*495ae853SAndroid Build Coastguard Worker     ps_cabac_ctxt->ps_lft_csbp = &ps_cabac_ctxt->s_lft_csbp;
154*495ae853SAndroid Build Coastguard Worker     ps_cabac_ctxt->ps_bitstrm = ps_ent_ctxt->ps_bitstrm;
155*495ae853SAndroid Build Coastguard Worker 
156*495ae853SAndroid Build Coastguard Worker     {
157*495ae853SAndroid Build Coastguard Worker         /* 0th entry of mb_map_ctxt_inc will be always be containing default values
158*495ae853SAndroid Build Coastguard Worker          */
159*495ae853SAndroid Build Coastguard Worker         /* for CABAC context representing MB not available                       */
160*495ae853SAndroid Build Coastguard Worker         isvce_mb_info_ctxt_t *ps_def_ctxt = ps_cabac_ctxt->ps_mb_map_ctxt_inc - 1;
161*495ae853SAndroid Build Coastguard Worker 
162*495ae853SAndroid Build Coastguard Worker         ps_def_ctxt->u1_mb_type = CAB_SKIP;
163*495ae853SAndroid Build Coastguard Worker         ps_def_ctxt->u1_cbp = 0x0f;
164*495ae853SAndroid Build Coastguard Worker         ps_def_ctxt->u1_intrapred_chroma_mode = 0;
165*495ae853SAndroid Build Coastguard Worker         ps_def_ctxt->u1_base_mode_flag = 0;
166*495ae853SAndroid Build Coastguard Worker 
167*495ae853SAndroid Build Coastguard Worker         memset(ps_def_ctxt->i1_ref_idx, 0, sizeof(ps_def_ctxt->i1_ref_idx));
168*495ae853SAndroid Build Coastguard Worker         memset(ps_def_ctxt->u1_mv, 0, sizeof(ps_def_ctxt->u1_mv));
169*495ae853SAndroid Build Coastguard Worker         ps_cabac_ctxt->ps_def_ctxt_mb_info = ps_def_ctxt;
170*495ae853SAndroid Build Coastguard Worker     }
171*495ae853SAndroid Build Coastguard Worker }
172*495ae853SAndroid Build Coastguard Worker 
173*495ae853SAndroid Build Coastguard Worker /**
174*495ae853SAndroid Build Coastguard Worker  *******************************************************************************
175*495ae853SAndroid Build Coastguard Worker  *
176*495ae853SAndroid Build Coastguard Worker  * @brief
177*495ae853SAndroid Build Coastguard Worker  * Initialize cabac context: Initialize all contest with init values given in
178*495ae853SAndroid Build Coastguard Worker  *the spec. Called at the beginning of entropy coding of each slice for CABAC
179*495ae853SAndroid Build Coastguard Worker  *encoding.
180*495ae853SAndroid Build Coastguard Worker  *
181*495ae853SAndroid Build Coastguard Worker  * @param[in] ps_ent_ctxt
182*495ae853SAndroid Build Coastguard Worker  *  Pointer to entropy context structure
183*495ae853SAndroid Build Coastguard Worker  *
184*495ae853SAndroid Build Coastguard Worker  * @returns
185*495ae853SAndroid Build Coastguard Worker  *
186*495ae853SAndroid Build Coastguard Worker  * @remarks
187*495ae853SAndroid Build Coastguard Worker  *  None
188*495ae853SAndroid Build Coastguard Worker  *
189*495ae853SAndroid Build Coastguard Worker  *******************************************************************************
190*495ae853SAndroid Build Coastguard Worker  */
isvce_init_cabac_ctxt(isvce_entropy_ctxt_t * ps_ent_ctxt,slice_header_t * ps_slice_hdr)191*495ae853SAndroid Build Coastguard Worker void isvce_init_cabac_ctxt(isvce_entropy_ctxt_t *ps_ent_ctxt, slice_header_t *ps_slice_hdr)
192*495ae853SAndroid Build Coastguard Worker {
193*495ae853SAndroid Build Coastguard Worker     isvce_cabac_ctxt_t *ps_cabac_ctxt = ps_ent_ctxt->ps_cabac;
194*495ae853SAndroid Build Coastguard Worker 
195*495ae853SAndroid Build Coastguard Worker     const UWORD8 u1_slice_type = ps_slice_hdr->u1_slice_type;
196*495ae853SAndroid Build Coastguard Worker     WORD8 i1_cabac_init_idc = 0;
197*495ae853SAndroid Build Coastguard Worker     bin_ctxt_model *au1_cabac_ctxt_table = ps_cabac_ctxt->au1_cabac_ctxt_table;
198*495ae853SAndroid Build Coastguard Worker     UWORD8 u1_qp_y = ps_slice_hdr->i1_slice_qp;
199*495ae853SAndroid Build Coastguard Worker 
200*495ae853SAndroid Build Coastguard Worker     isvce_init_cabac_enc_envirnoment(&ps_cabac_ctxt->s_cab_enc_env);
201*495ae853SAndroid Build Coastguard Worker 
202*495ae853SAndroid Build Coastguard Worker     ps_cabac_ctxt->i1_prevps_mb_qp_delta_ctxt = 0;
203*495ae853SAndroid Build Coastguard Worker 
204*495ae853SAndroid Build Coastguard Worker     if(ISLICE != u1_slice_type)
205*495ae853SAndroid Build Coastguard Worker     {
206*495ae853SAndroid Build Coastguard Worker         i1_cabac_init_idc = ps_slice_hdr->i1_cabac_init_idc;
207*495ae853SAndroid Build Coastguard Worker     }
208*495ae853SAndroid Build Coastguard Worker     else
209*495ae853SAndroid Build Coastguard Worker     {
210*495ae853SAndroid Build Coastguard Worker         i1_cabac_init_idc = 3;
211*495ae853SAndroid Build Coastguard Worker     }
212*495ae853SAndroid Build Coastguard Worker 
213*495ae853SAndroid Build Coastguard Worker     memcpy(au1_cabac_ctxt_table, gau1_isvc_cabac_ctxt_init_table[i1_cabac_init_idc][u1_qp_y],
214*495ae853SAndroid Build Coastguard Worker            NUM_SVC_CABAC_CTXTS * sizeof(bin_ctxt_model));
215*495ae853SAndroid Build Coastguard Worker }
216