ih264e_cabac_init.c revision 3749f6f435e79624f72841e866245d84195551cd
1/****************************************************************************** 2 * 3 * Copyright (C) 2015 The Android Open Source Project 4 * 5 * Licensed under the Apache License, Version 2.0 (the "License"); 6 * you may not use this file except in compliance with the License. 7 * You may obtain a copy of the License at: 8 * 9 * http://www.apache.org/licenses/LICENSE-2.0 10 * 11 * Unless required by applicable law or agreed to in writing, software 12 * distributed under the License is distributed on an "AS IS" BASIS, 13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14 * See the License for the specific language governing permissions and 15 * limitations under the License. 16 * 17 ***************************************************************************** 18 * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore 19*/ 20 21/** 22******************************************************************************* 23* @file 24* ih264e_cabac_init.c 25* 26* @brief 27* Contains all initialization functions for cabac contexts 28* 29* @author 30* Doney Alex 31* 32* @par List of Functions: 33* 34* 35* @remarks 36* None 37* 38******************************************************************************* 39*/ 40 41/*****************************************************************************/ 42/* File Includes */ 43/*****************************************************************************/ 44 45/* System include files */ 46#include <stdio.h> 47#include <stddef.h> 48#include <stdlib.h> 49#include <string.h> 50#include <limits.h> 51#include <assert.h> 52 53/* User include files */ 54#include "ih264_typedefs.h" 55#include "iv2.h" 56#include "ive2.h" 57#include "ih264_defs.h" 58#include "ih264_debug.h" 59#include "ime_distortion_metrics.h" 60#include "ime_defs.h" 61#include "ime_structs.h" 62#include "ih264_error.h" 63#include "ih264_structs.h" 64#include "ih264_trans_quant_itrans_iquant.h" 65#include "ih264_inter_pred_filters.h" 66#include "ih264_mem_fns.h" 67#include "ih264_padding.h" 68#include "ih264_intra_pred_filters.h" 69#include "ih264_deblk_edge_filters.h" 70#include "ih264_platform_macros.h" 71#include "ih264_macros.h" 72#include "ih264_buf_mgr.h" 73#include "ih264e_error.h" 74#include "ih264e_bitstream.h" 75#include "ih264_common_tables.h" 76#include "ih264_cabac_tables.h" 77#include "ih264_list.h" 78#include "ih264e_defs.h" 79#include "irc_cntrl_param.h" 80#include "irc_frame_info_collector.h" 81#include "ih264e_rate_control.h" 82#include "ih264e_cabac_structs.h" 83#include "ih264e_structs.h" 84#include "ih264e_cabac.h" 85#include "ih264e_process.h" 86#include "ithread.h" 87#include "ih264e_intra_modes_eval.h" 88#include "ih264e_encode_header.h" 89#include "ih264e_globals.h" 90#include "ih264e_config.h" 91#include "ih264e_trace.h" 92#include "ih264e_statistics.h" 93#include "ih264_cavlc_tables.h" 94#include "ih264e_deblk.h" 95#include "ih264e_me.h" 96#include "ih264e_debug.h" 97#include "ih264e_master.h" 98#include "ih264e_utils.h" 99#include "irc_mem_req_and_acq.h" 100#include "irc_rate_control_api.h" 101#include "ih264e_platform_macros.h" 102#include "ime_statistics.h" 103 104 105 106/*****************************************************************************/ 107/* Function definitions . */ 108/*****************************************************************************/ 109 110/** 111 ******************************************************************************* 112 * 113 * @brief 114 * Initialize cabac encoding environment 115 * 116 * @param[in] ps_cab_enc_env 117 * Pointer to encoding_envirnoment_t structure 118 * 119 * @returns 120 * 121 * @remarks 122 * None 123 * 124 ******************************************************************************* 125*/ 126static void ih264e_init_cabac_enc_envirnoment(encoding_envirnoment_t *ps_cab_enc_env) 127{ 128 ps_cab_enc_env->u4_code_int_low = 0; 129 ps_cab_enc_env->u4_code_int_range = 0x1fe; 130 ps_cab_enc_env->u4_out_standing_bytes = 0; 131 ps_cab_enc_env->u4_bits_gen = 0; 132} 133 134 135/** 136 ******************************************************************************* 137 * 138 * @brief 139 * Initialize default context values and pointers (Called once at the beginning of encoding). 140 * 141 * @param[in] ps_ent_ctxt 142 * Pointer to entropy context structure 143 * 144 * @returns 145 * 146 * @remarks 147 * None 148 * 149 ******************************************************************************* 150*/ 151void ih264e_init_cabac_table(entropy_ctxt_t *ps_ent_ctxt) 152{ 153 /* CABAC context */ 154 cabac_ctxt_t *ps_cabac_ctxt = ps_ent_ctxt->ps_cabac; 155 ps_cabac_ctxt->ps_mb_map_ctxt_inc = ps_cabac_ctxt->ps_mb_map_ctxt_inc_base + 1; 156 ps_cabac_ctxt->ps_lft_csbp = &ps_cabac_ctxt->s_lft_csbp; 157 ps_cabac_ctxt->ps_bitstrm = ps_ent_ctxt->ps_bitstrm; 158 159 { 160 /* 0th entry of mb_map_ctxt_inc will be always be containing default values */ 161 /* for CABAC context representing MB not available */ 162 mb_info_ctxt_t *ps_def_ctxt = ps_cabac_ctxt->ps_mb_map_ctxt_inc - 1; 163 UWORD32 *pu4_temp; 164 WORD8 i; 165 166 ps_def_ctxt->u1_mb_type = CAB_SKIP; 167 ps_def_ctxt->u1_cbp = 0x0f; 168 ps_def_ctxt->u1_intrapred_chroma_mode = 0; 169 pu4_temp = (UWORD32 *)ps_def_ctxt->i1_ref_idx; 170 pu4_temp[0] = 0; 171 pu4_temp = (UWORD32 *)ps_def_ctxt->u1_mv; 172 for (i = 0; i < 4; i++, pu4_temp++) 173 (*pu4_temp) = 0; 174 ps_cabac_ctxt->ps_def_ctxt_mb_info = ps_def_ctxt; 175 } 176} 177 178 179/** 180 ******************************************************************************* 181 * 182 * @brief 183 * Initialize cabac context: Initialize all contest with init values given in the spec. 184 * Called at the beginning of entropy coding of each slice for CABAC encoding. 185 * 186 * @param[in] ps_ent_ctxt 187 * Pointer to entropy context structure 188 * 189 * @returns 190 * 191 * @remarks 192 * None 193 * 194 ******************************************************************************* 195 */ 196void ih264e_init_cabac_ctxt(entropy_ctxt_t *ps_ent_ctxt) 197{ 198 /* CABAC context */ 199 cabac_ctxt_t *ps_cabac_ctxt = ps_ent_ctxt->ps_cabac; 200 201 /* slice header */ 202 slice_header_t *ps_slice_hdr = ps_ent_ctxt->ps_slice_hdr_base; 203 const UWORD8 u1_slice_type = ps_slice_hdr->u1_slice_type; 204 WORD8 i1_cabac_init_idc = 0; 205 bin_ctxt_model *au1_cabac_ctxt_table = ps_cabac_ctxt->au1_cabac_ctxt_table; 206 UWORD8 u1_qp_y = ps_slice_hdr->i1_slice_qp; 207 208 ih264e_init_cabac_enc_envirnoment(&ps_cabac_ctxt->s_cab_enc_env); 209 210 ps_cabac_ctxt->i1_prevps_mb_qp_delta_ctxt = 0; 211 212 if (ISLICE != u1_slice_type) 213 { 214 i1_cabac_init_idc = ps_slice_hdr->i1_cabac_init_idc; 215 } 216 else 217 { 218 i1_cabac_init_idc = 3; 219 220 } 221 222 memcpy(au1_cabac_ctxt_table, 223 gau1_ih264_cabac_ctxt_init_table[i1_cabac_init_idc][u1_qp_y], 224 NUM_CABAC_CTXTS * sizeof(bin_ctxt_model)); 225 226} 227