149 lines
6.1 KiB
C
149 lines
6.1 KiB
C
|
|
/******************************************************************************
|
||
|
|
*
|
||
|
|
* Copyright (C) 2022 The Android Open Source Project
|
||
|
|
*
|
||
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||
|
|
* you may not use this file except in compliance with the License.
|
||
|
|
* You may obtain a copy of the License at:
|
||
|
|
*
|
||
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||
|
|
*
|
||
|
|
* Unless required by applicable law or agreed to in writing, software
|
||
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
|
|
* See the License for the specific language governing permissions and
|
||
|
|
* limitations under the License.
|
||
|
|
*
|
||
|
|
*****************************************************************************
|
||
|
|
* Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
|
||
|
|
*/
|
||
|
|
/**
|
||
|
|
*******************************************************************************
|
||
|
|
* @file
|
||
|
|
* isvcd_cabac.c
|
||
|
|
*
|
||
|
|
* @brief
|
||
|
|
* This file contains Binary decoding routines.
|
||
|
|
*
|
||
|
|
* @author
|
||
|
|
* Kishore
|
||
|
|
*
|
||
|
|
* @par List of Functions:
|
||
|
|
* - isvcd_init_cabac_contexts()
|
||
|
|
*
|
||
|
|
* @remarks
|
||
|
|
* None
|
||
|
|
*
|
||
|
|
*******************************************************************************
|
||
|
|
*/
|
||
|
|
|
||
|
|
#include <string.h>
|
||
|
|
#include "ih264_typedefs.h"
|
||
|
|
#include "ih264_macros.h"
|
||
|
|
#include "ih264_platform_macros.h"
|
||
|
|
#include "isvcd_structs.h"
|
||
|
|
#include "ih264d_cabac.h"
|
||
|
|
#include "isvcd_cabac.h"
|
||
|
|
#include "ih264d_bitstrm.h"
|
||
|
|
#include "ih264d_error_handler.h"
|
||
|
|
#include "ih264d_defs.h"
|
||
|
|
#include "ih264d_debug.h"
|
||
|
|
#include "ih264d_tables.h"
|
||
|
|
#include "isvcd_tables.h"
|
||
|
|
#include "ih264d_parse_cabac.h"
|
||
|
|
#include "ih264d_tables.h"
|
||
|
|
|
||
|
|
/*****************************************************************************/
|
||
|
|
/* */
|
||
|
|
/* Function Name : isvcd_init_cabac_contexts */
|
||
|
|
/* */
|
||
|
|
/* Description : This function initializes the cabac contexts */
|
||
|
|
/* depending upon slice type and Init_Idc value. */
|
||
|
|
/* Inputs : ps_dec, slice type */
|
||
|
|
/* Globals : <Does it use any global variables?> */
|
||
|
|
/* Outputs : */
|
||
|
|
/* Returns : void */
|
||
|
|
/* */
|
||
|
|
/* Issues : none */
|
||
|
|
/* */
|
||
|
|
/* Revision History: */
|
||
|
|
/* */
|
||
|
|
/* DD MM YYYY Author(s) Changes (Describe the changes made) */
|
||
|
|
/* 06 09 2021 Kishore Draft */
|
||
|
|
/* */
|
||
|
|
/*****************************************************************************/
|
||
|
|
|
||
|
|
void isvcd_init_cabac_contexts(UWORD8 u1_slice_type, dec_struct_t *ps_dec)
|
||
|
|
{
|
||
|
|
bin_ctxt_model_t *p_cabac_ctxt_table_t = ps_dec->p_cabac_ctxt_table_t;
|
||
|
|
UWORD8 u1_qp_y = ps_dec->ps_cur_slice->u1_slice_qp;
|
||
|
|
UWORD8 u1_cabac_init_Idc = 0;
|
||
|
|
|
||
|
|
if(I_SLICE != u1_slice_type)
|
||
|
|
{
|
||
|
|
u1_cabac_init_Idc = ps_dec->ps_cur_slice->u1_cabac_init_idc;
|
||
|
|
}
|
||
|
|
|
||
|
|
{
|
||
|
|
/* MAKING ps_dec->p_ctxt_inc_mb_map a scratch buffer */
|
||
|
|
/* 0th entry of CtxtIncMbMap will be always be containing default values
|
||
|
|
for CABAC context representing MB not available */
|
||
|
|
ctxt_inc_mb_info_t *p_DefCtxt = ps_dec->p_ctxt_inc_mb_map - 1;
|
||
|
|
UWORD8 *pu1_temp;
|
||
|
|
WORD8 i;
|
||
|
|
p_DefCtxt->u1_mb_type = CAB_SKIP;
|
||
|
|
p_DefCtxt->u1_cbp = 0x0f;
|
||
|
|
p_DefCtxt->u1_intra_chroma_pred_mode = 0;
|
||
|
|
p_DefCtxt->u1_yuv_dc_csbp = 0x7;
|
||
|
|
p_DefCtxt->u1_transform8x8_ctxt = 0;
|
||
|
|
|
||
|
|
pu1_temp = (UWORD8 *) p_DefCtxt->i1_ref_idx;
|
||
|
|
for(i = 0; i < 4; i++, pu1_temp++) (*pu1_temp) = 0;
|
||
|
|
pu1_temp = (UWORD8 *) p_DefCtxt->u1_mv;
|
||
|
|
for(i = 0; i < 16; i++, pu1_temp++) (*pu1_temp) = 0;
|
||
|
|
ps_dec->ps_def_ctxt_mb_info = p_DefCtxt;
|
||
|
|
}
|
||
|
|
|
||
|
|
if(u1_slice_type == I_SLICE)
|
||
|
|
{
|
||
|
|
u1_cabac_init_Idc = 3;
|
||
|
|
ps_dec->p_mb_type_t = p_cabac_ctxt_table_t + MB_TYPE_I_SLICE;
|
||
|
|
}
|
||
|
|
else if(u1_slice_type == P_SLICE)
|
||
|
|
{
|
||
|
|
ps_dec->p_mb_type_t = p_cabac_ctxt_table_t + MB_TYPE_P_SLICE;
|
||
|
|
ps_dec->p_mb_skip_flag_t = p_cabac_ctxt_table_t + MB_SKIP_FLAG_P_SLICE;
|
||
|
|
ps_dec->p_sub_mb_type_t = p_cabac_ctxt_table_t + SUB_MB_TYPE_P_SLICE;
|
||
|
|
}
|
||
|
|
else if(u1_slice_type == B_SLICE)
|
||
|
|
{
|
||
|
|
ps_dec->p_mb_type_t = p_cabac_ctxt_table_t + MB_TYPE_B_SLICE;
|
||
|
|
ps_dec->p_mb_skip_flag_t = p_cabac_ctxt_table_t + MB_SKIP_FLAG_B_SLICE;
|
||
|
|
ps_dec->p_sub_mb_type_t = p_cabac_ctxt_table_t + SUB_MB_TYPE_B_SLICE;
|
||
|
|
}
|
||
|
|
{
|
||
|
|
bin_ctxt_model_t *p_cabac_ctxt_table_t_tmp = p_cabac_ctxt_table_t;
|
||
|
|
if(ps_dec->ps_cur_slice->u1_field_pic_flag)
|
||
|
|
{
|
||
|
|
p_cabac_ctxt_table_t_tmp += SIGNIFICANT_COEFF_FLAG_FLD;
|
||
|
|
}
|
||
|
|
else
|
||
|
|
{
|
||
|
|
p_cabac_ctxt_table_t_tmp += SIGNIFICANT_COEFF_FLAG_FRAME;
|
||
|
|
}
|
||
|
|
{
|
||
|
|
bin_ctxt_model_t **p_significant_coeff_flag_t = ps_dec->p_significant_coeff_flag_t;
|
||
|
|
p_significant_coeff_flag_t[0] = p_cabac_ctxt_table_t_tmp + SIG_COEFF_CTXT_CAT_0_OFFSET;
|
||
|
|
p_significant_coeff_flag_t[1] = p_cabac_ctxt_table_t_tmp + SIG_COEFF_CTXT_CAT_1_OFFSET;
|
||
|
|
p_significant_coeff_flag_t[2] = p_cabac_ctxt_table_t_tmp + SIG_COEFF_CTXT_CAT_2_OFFSET;
|
||
|
|
p_significant_coeff_flag_t[3] = p_cabac_ctxt_table_t_tmp + SIG_COEFF_CTXT_CAT_3_OFFSET;
|
||
|
|
p_significant_coeff_flag_t[4] = p_cabac_ctxt_table_t_tmp + SIG_COEFF_CTXT_CAT_4_OFFSET;
|
||
|
|
|
||
|
|
p_significant_coeff_flag_t[5] = p_cabac_ctxt_table_t_tmp + SIG_COEFF_CTXT_CAT_5_OFFSET;
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
memcpy(p_cabac_ctxt_table_t, gau1_isvcd_cabac_ctxt_init_table[u1_cabac_init_Idc][u1_qp_y],
|
||
|
|
NUM_CABAC_CTXTS_SVC * sizeof(bin_ctxt_model_t));
|
||
|
|
}
|