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