xref: /aosp_15_r20/external/libavc/encoder/ih264e_cabac.h (revision 495ae853bb871d1e5a258cb02c2cc13cde8ddb9a)
1*495ae853SAndroid Build Coastguard Worker /******************************************************************************
2*495ae853SAndroid Build Coastguard Worker  *
3*495ae853SAndroid Build Coastguard Worker  * Copyright (C) 2015 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 *  ih264e_cabac.h
25*495ae853SAndroid Build Coastguard Worker *
26*495ae853SAndroid Build Coastguard Worker * @brief
27*495ae853SAndroid Build Coastguard Worker *  This file contains declarations necessary for cabac encoding
28*495ae853SAndroid Build Coastguard Worker *
29*495ae853SAndroid Build Coastguard Worker * @author
30*495ae853SAndroid Build Coastguard Worker *  ittiam
31*495ae853SAndroid Build Coastguard Worker *
32*495ae853SAndroid Build Coastguard Worker * @remarks
33*495ae853SAndroid Build Coastguard Worker *  none
34*495ae853SAndroid Build Coastguard Worker *
35*495ae853SAndroid Build Coastguard Worker *******************************************************************************
36*495ae853SAndroid Build Coastguard Worker */
37*495ae853SAndroid Build Coastguard Worker 
38*495ae853SAndroid Build Coastguard Worker #ifndef _IH264E_CABAC_H_
39*495ae853SAndroid Build Coastguard Worker #define _IH264E_CABAC_H_
40*495ae853SAndroid Build Coastguard Worker 
41*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
42*495ae853SAndroid Build Coastguard Worker /* Macros                                                                    */
43*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
44*495ae853SAndroid Build Coastguard Worker 
45*495ae853SAndroid Build Coastguard Worker /**
46*495ae853SAndroid Build Coastguard Worker *******************************************************************************
47*495ae853SAndroid Build Coastguard Worker *  @brief Bit precision of cabac engine;
48*495ae853SAndroid Build Coastguard Worker *******************************************************************************
49*495ae853SAndroid Build Coastguard Worker */
50*495ae853SAndroid Build Coastguard Worker #define CABAC_BITS  9
51*495ae853SAndroid Build Coastguard Worker 
52*495ae853SAndroid Build Coastguard Worker /**
53*495ae853SAndroid Build Coastguard Worker *******************************************************************************
54*495ae853SAndroid Build Coastguard Worker *  @macro Reverse bits in an unsigned integer
55*495ae853SAndroid Build Coastguard Worker *******************************************************************************
56*495ae853SAndroid Build Coastguard Worker */
57*495ae853SAndroid Build Coastguard Worker #define REV(u4_input, u4_output)                 \
58*495ae853SAndroid Build Coastguard Worker {                                                \
59*495ae853SAndroid Build Coastguard Worker     UWORD32 u4_temp = (u4_input);                \
60*495ae853SAndroid Build Coastguard Worker     WORD8 i;                                     \
61*495ae853SAndroid Build Coastguard Worker     u4_output = 0;                               \
62*495ae853SAndroid Build Coastguard Worker     for (i = 0; i < 32; i++)                     \
63*495ae853SAndroid Build Coastguard Worker     {                                            \
64*495ae853SAndroid Build Coastguard Worker         u4_output = (u4_output << 1) +           \
65*495ae853SAndroid Build Coastguard Worker                         ((u4_temp >> i) & 0x01); \
66*495ae853SAndroid Build Coastguard Worker     }                                            \
67*495ae853SAndroid Build Coastguard Worker }
68*495ae853SAndroid Build Coastguard Worker 
69*495ae853SAndroid Build Coastguard Worker /**
70*495ae853SAndroid Build Coastguard Worker *******************************************************************************
71*495ae853SAndroid Build Coastguard Worker *! Bit manipulation macros
72*495ae853SAndroid Build Coastguard Worker *******************************************************************************
73*495ae853SAndroid Build Coastguard Worker */
74*495ae853SAndroid Build Coastguard Worker #define SETBIT(a, i)   ((a) |= (1 << (i)))
75*495ae853SAndroid Build Coastguard Worker #define CLEARBIT(a, i) ((a) &= ~(1 << (i)))
76*495ae853SAndroid Build Coastguard Worker 
77*495ae853SAndroid Build Coastguard Worker /**
78*495ae853SAndroid Build Coastguard Worker *******************************************************************************
79*495ae853SAndroid Build Coastguard Worker *! Cabac module expect atlesat MIN_STREAM_SIZE_MB bytes left in stream buffer
80*495ae853SAndroid Build Coastguard Worker *! for encoding an MB
81*495ae853SAndroid Build Coastguard Worker *******************************************************************************
82*495ae853SAndroid Build Coastguard Worker */
83*495ae853SAndroid Build Coastguard Worker #define MIN_STREAM_SIZE_MB   1024
84*495ae853SAndroid Build Coastguard Worker 
85*495ae853SAndroid Build Coastguard Worker 
86*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
87*495ae853SAndroid Build Coastguard Worker /* Function Declarations                                                     */
88*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
89*495ae853SAndroid Build Coastguard Worker 
90*495ae853SAndroid Build Coastguard Worker void ih264e_init_cabac_table(entropy_ctxt_t *ps_ent_ctxt);
91*495ae853SAndroid Build Coastguard Worker 
92*495ae853SAndroid Build Coastguard Worker void ih264e_init_cabac_ctxt(entropy_ctxt_t *ps_ent_ctxt);
93*495ae853SAndroid Build Coastguard Worker 
94*495ae853SAndroid Build Coastguard Worker UWORD32 ih264e_cabac_UEGk0_binarization(WORD16 i2_sufs, WORD8 *pi1_bins_len);
95*495ae853SAndroid Build Coastguard Worker 
96*495ae853SAndroid Build Coastguard Worker void ih264e_get_cabac_context(entropy_ctxt_t *ps_ent_ctxt, WORD32 u4_mb_type);
97*495ae853SAndroid Build Coastguard Worker 
98*495ae853SAndroid Build Coastguard Worker IH264E_ERROR_T ih264e_cabac_flush(cabac_ctxt_t *ps_cabac_ctxt);
99*495ae853SAndroid Build Coastguard Worker 
100*495ae853SAndroid Build Coastguard Worker IH264E_ERROR_T ih264e_cabac_put_byte(cabac_ctxt_t *ps_cabac_ctxt);
101*495ae853SAndroid Build Coastguard Worker 
102*495ae853SAndroid Build Coastguard Worker void ih264e_cabac_encode_bin(cabac_ctxt_t *ps_cabac, WORD32 bin,
103*495ae853SAndroid Build Coastguard Worker                              bin_ctxt_model *pu1_bin_ctxts);
104*495ae853SAndroid Build Coastguard Worker 
105*495ae853SAndroid Build Coastguard Worker void ih264e_encode_decision_bins(UWORD32 u4_bins, WORD8 i1_bins_len,
106*495ae853SAndroid Build Coastguard Worker                                  UWORD32 u4_ctx_inc, WORD8 i1_valid_len,
107*495ae853SAndroid Build Coastguard Worker                                  bin_ctxt_model *pu1_bin_ctxt_type,
108*495ae853SAndroid Build Coastguard Worker                                  cabac_ctxt_t *ps_cabac);
109*495ae853SAndroid Build Coastguard Worker 
110*495ae853SAndroid Build Coastguard Worker void ih264e_cabac_encode_terminate(cabac_ctxt_t *ps_cabac, WORD32 term_bin);
111*495ae853SAndroid Build Coastguard Worker 
112*495ae853SAndroid Build Coastguard Worker void ih264e_cabac_encode_bypass_bin(cabac_ctxt_t *ps_cabac, WORD32 bin);
113*495ae853SAndroid Build Coastguard Worker 
114*495ae853SAndroid Build Coastguard Worker void ih264e_cabac_encode_bypass_bins(cabac_ctxt_t *ps_cabac, UWORD32 u4_bins,
115*495ae853SAndroid Build Coastguard Worker                                      WORD32 num_bins);
116*495ae853SAndroid Build Coastguard Worker 
117*495ae853SAndroid Build Coastguard Worker IH264E_ERROR_T ih264e_write_islice_mb_cabac(entropy_ctxt_t *ps_ent_ctxt);
118*495ae853SAndroid Build Coastguard Worker 
119*495ae853SAndroid Build Coastguard Worker IH264E_ERROR_T ih264e_write_pslice_mb_cabac(entropy_ctxt_t *ps_ent_ctxt);
120*495ae853SAndroid Build Coastguard Worker 
121*495ae853SAndroid Build Coastguard Worker IH264E_ERROR_T ih264e_write_bslice_mb_cabac(entropy_ctxt_t *ps_ent_ctxt);
122*495ae853SAndroid Build Coastguard Worker 
123*495ae853SAndroid Build Coastguard Worker #endif /* _IH264E_CABAC_H_ */
124