You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1608 lines
62 KiB

/******************************************************************************
*
* Copyright (C) 2015 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 ih264d_parse_cabac.c
*
* \brief
* This file contains cabac Residual decoding routines.
*
* \date
* 20/03/2003
*
* \author NS
***************************************************************************
*/
#include "ih264_typedefs.h"
#include "ih264_macros.h"
#include "ih264_platform_macros.h"
#include "ih264d_defs.h"
#include "ih264d_structs.h"
#include "ih264d_cabac.h"
#include "ih264d_bitstrm.h"
#include "ih264d_parse_mb_header.h"
#include "ih264d_debug.h"
#include "ih264d_tables.h"
#include "ih264d_error_handler.h"
#include "ih264d_parse_cabac.h"
#include "ih264d_parse_slice.h"
#include "ih264d_tables.h"
#include "ih264d_mb_utils.h"
#include "ih264d_utils.h"
/*!
********************************************************************************
* \if Function name : ih264d_read_coeff4x4_cabac \endif
*
* \brief This function encodes residual_block_cabac as defined in 7.3.5.3.2.
*
* \return
* Returns the index of last significant coeff.
*
********************************************************************************
*/
UWORD8 ih264d_read_coeff4x4_cabac(dec_bit_stream_t *ps_bitstrm,
UWORD32 u4_ctxcat,
bin_ctxt_model_t *ps_ctxt_sig_coeff,
dec_struct_t *ps_dec, /*!< pointer to access global variables*/
bin_ctxt_model_t *ps_ctxt_coded)
{
decoding_envirnoment_t *ps_cab_env = &ps_dec->s_cab_dec_env;
UWORD32 u4_coded_flag;
UWORD32 u4_offset, *pu4_buffer;
UWORD32 u4_code_int_range, u4_code_int_val_ofst;
tu_sblk4x4_coeff_data_t *ps_tu_4x4;
WORD16 *pi2_coeff_data;
WORD32 num_sig_coeffs = 0;
/*loading from strcuctures*/
ps_tu_4x4 = (tu_sblk4x4_coeff_data_t *)ps_dec->pv_parse_tu_coeff_data;
ps_tu_4x4->u2_sig_coeff_map = 0;
pi2_coeff_data = &ps_tu_4x4->ai2_level[0];
u4_offset = ps_bitstrm->u4_ofst;
pu4_buffer = ps_bitstrm->pu4_buffer;
u4_code_int_range = ps_cab_env->u4_code_int_range;
u4_code_int_val_ofst = ps_cab_env->u4_code_int_val_ofst;
{
/*inilined DecodeDecision_onebin begins*/
{
UWORD32 u4_qnt_int_range, u4_int_range_lps;
UWORD32 u4_symbol, u1_mps_state;
UWORD32 table_lookup;
const UWORD32 *pu4_table = (const UWORD32 *)ps_cab_env->cabac_table;
UWORD32 u4_clz;
u1_mps_state = (ps_ctxt_coded->u1_mps_state);
u4_clz = CLZ(u4_code_int_range);
u4_qnt_int_range = u4_code_int_range << u4_clz;
u4_qnt_int_range = (u4_qnt_int_range >> 29) & 0x3;
table_lookup =
pu4_table[(u1_mps_state << 2) + u4_qnt_int_range];
u4_int_range_lps = table_lookup & 0xff;
u4_int_range_lps = u4_int_range_lps << (23 - u4_clz);
u4_code_int_range = u4_code_int_range - u4_int_range_lps;
u4_symbol = ((u1_mps_state >> 6) & 0x1);
u1_mps_state = (table_lookup >> 8) & 0x7F;
CHECK_IF_LPS(u4_code_int_range, u4_code_int_val_ofst, u4_symbol,
u4_int_range_lps, u1_mps_state, table_lookup)
if(u4_code_int_range < ONE_RIGHT_SHIFTED_BY_8)
{
RENORM_RANGE_OFFSET(u4_code_int_range, u4_code_int_val_ofst,
u4_offset, pu4_buffer)
}
ps_ctxt_coded->u1_mps_state = u1_mps_state;
u4_coded_flag = u4_symbol;
/*inilined DecodeDecision_onebin ends*/
}
}
if(u4_coded_flag)
{
{
bin_ctxt_model_t *p_binCtxt_last, *p_binCtxt_last_org;
UWORD32 uc_last_coeff_idx;
UWORD32 uc_bin;
UWORD32 i;
WORD32 first_coeff_offset = 0;
if((u4_ctxcat == CHROMA_AC_CTXCAT) || (u4_ctxcat == LUMA_AC_CTXCAT))
{
first_coeff_offset = 1;
}
i = 0;
if(u4_ctxcat == CHROMA_DC_CTXCAT)
{
uc_last_coeff_idx = 3;
}
else
{
UWORD32 u4_start;
u4_start = (u4_ctxcat & 1) + (u4_ctxcat >> 2);
uc_last_coeff_idx = 15 - u4_start;
}
p_binCtxt_last_org = ps_ctxt_sig_coeff
+ LAST_COEFF_CTXT_MINUS_SIG_COEFF_CTXT;
do
{
/*inilined DecodeDecision_onebin begins*/
{
UWORD32 u4_qnt_int_range, u4_int_range_lps;
UWORD32 u4_symbol, u1_mps_state;
UWORD32 table_lookup;
const UWORD32 *pu4_table =
(const UWORD32 *)ps_cab_env->cabac_table;
UWORD32 u4_clz;
u1_mps_state = (ps_ctxt_sig_coeff->u1_mps_state);
u4_clz = CLZ(u4_code_int_range);
u4_qnt_int_range = u4_code_int_range << u4_clz;
u4_qnt_int_range = (u4_qnt_int_range >> 29) & 0x3;
table_lookup = pu4_table[(u1_mps_state << 2)
+ u4_qnt_int_range];
u4_int_range_lps = table_lookup & 0xff;
u4_int_range_lps = u4_int_range_lps << (23 - u4_clz);
u4_code_int_range = u4_code_int_range - u4_int_range_lps;
u4_symbol = ((u1_mps_state >> 6) & 0x1);
u1_mps_state = (table_lookup >> 8) & 0x7F;
CHECK_IF_LPS(u4_code_int_range, u4_code_int_val_ofst,
u4_symbol, u4_int_range_lps, u1_mps_state,
table_lookup)
if(u4_code_int_range < ONE_RIGHT_SHIFTED_BY_14)
{
UWORD32 read_bits, u4_clz;
u4_clz = CLZ(u4_code_int_range);
NEXTBITS(read_bits, (u4_offset + 23), pu4_buffer,
u4_clz)
FLUSHBITS(u4_offset, (u4_clz))
u4_code_int_range = u4_code_int_range << u4_clz;
u4_code_int_val_ofst = (u4_code_int_val_ofst << u4_clz)
| read_bits;
}
INC_BIN_COUNT(
ps_cab_env)
ps_ctxt_sig_coeff->u1_mps_state = u1_mps_state;
uc_bin = u4_symbol;
}
/*incrementing pointer to point to the context of the next bin*/
ps_ctxt_sig_coeff++;
/*inilined DecodeDecision_onebin ends*/
if(uc_bin)
{
num_sig_coeffs++;
SET_BIT(ps_tu_4x4->u2_sig_coeff_map, (i + first_coeff_offset));
p_binCtxt_last = p_binCtxt_last_org + i;
/*inilined DecodeDecision_onebin begins*/
{
UWORD32 u4_qnt_int_range, u4_int_range_lps;
UWORD32 u4_symbol, u1_mps_state;
UWORD32 table_lookup;
const UWORD32 *pu4_table =
(const UWORD32 *)ps_cab_env->cabac_table;
UWORD32 u4_clz;
u1_mps_state = (p_binCtxt_last->u1_mps_state);
u4_clz = CLZ(u4_code_int_range);
u4_qnt_int_range = u4_code_int_range << u4_clz;
u4_qnt_int_range = (u4_qnt_int_range >> 29)
& 0x3;
table_lookup = pu4_table[(u1_mps_state << 2)
+ u4_qnt_int_range];
u4_int_range_lps = table_lookup & 0xff;
u4_int_range_lps = u4_int_range_lps
<< (23 - u4_clz);
u4_code_int_range = u4_code_int_range
- u4_int_range_lps;
u4_symbol = ((u1_mps_state >> 6) & 0x1);
u1_mps_state = (table_lookup >> 8) & 0x7F;
CHECK_IF_LPS(u4_code_int_range, u4_code_int_val_ofst,
u4_symbol, u4_int_range_lps,
u1_mps_state, table_lookup)
INC_BIN_COUNT(ps_cab_env)
p_binCtxt_last->u1_mps_state = u1_mps_state;
uc_bin = u4_symbol;
}
/*inilined DecodeDecision_onebin ends*/
if(uc_bin == 1)
goto label_read_levels;
}
i = i + 1;
}
while(i < uc_last_coeff_idx);
num_sig_coeffs++;
SET_BIT(ps_tu_4x4->u2_sig_coeff_map, (i + first_coeff_offset));
label_read_levels: ;
}
/// VALUE of No of Coeff in BLOCK = i + 1 for second case else i;
/* Decode coeff_abs_level_minus1 and coeff_sign_flag */
{
WORD32 i2_abs_lvl;
UWORD32 u1_abs_level_equal1 = 1, u1_abs_level_gt1 = 0;
UWORD32 u4_ctx_inc;
UWORD32 ui_prefix;
bin_ctxt_model_t *p_ctxt_abs_level;
p_ctxt_abs_level = ps_dec->p_coeff_abs_level_minus1_t[u4_ctxcat];
u4_ctx_inc = ((0x51));
/*****************************************************/
/* Main Loop runs for no. of Significant coefficient */
/*****************************************************/
do
{
{
INC_SYM_COUNT(&(ps_dec.s_cab_dec_env));
/*****************************************************/
/* inilining a modified ih264d_decode_bins_unary */
/*****************************************************/
{
UWORD32 u4_value;
UWORD32 u4_symbol;
bin_ctxt_model_t *ps_bin_ctxt;
UWORD32 u4_ctx_Inc;
u4_value = 0;
u4_ctx_Inc = u4_ctx_inc & 0xf;
ps_bin_ctxt = p_ctxt_abs_level + u4_ctx_Inc;
do
{
{
UWORD32 u4_qnt_int_range,
u4_int_range_lps;
UWORD32 u1_mps_state;
UWORD32 table_lookup;
const UWORD32 *pu4_table =
(const UWORD32 *)ps_cab_env->cabac_table;
UWORD32 u4_clz;
u1_mps_state = (ps_bin_ctxt->u1_mps_state);
u4_clz = CLZ(u4_code_int_range);
u4_qnt_int_range = u4_code_int_range
<< u4_clz;
u4_qnt_int_range = (u4_qnt_int_range
>> 29) & 0x3;
table_lookup = pu4_table[(u1_mps_state << 2)
+ u4_qnt_int_range];
u4_int_range_lps = table_lookup & 0xff;
u4_int_range_lps = u4_int_range_lps
<< (23 - u4_clz);
u4_code_int_range = u4_code_int_range
- u4_int_range_lps;
u4_symbol = ((u1_mps_state >> 6) & 0x1);
u1_mps_state = (table_lookup >> 8) & 0x7F;
CHECK_IF_LPS(u4_code_int_range,
u4_code_int_val_ofst, u4_symbol,
u4_int_range_lps, u1_mps_state,
table_lookup)
if(u4_code_int_range < ONE_RIGHT_SHIFTED_BY_9)
{
RENORM_RANGE_OFFSET(u4_code_int_range,
u4_code_int_val_ofst,
u4_offset, pu4_buffer)
}
INC_BIN_COUNT(ps_cab_env);
ps_bin_ctxt->u1_mps_state = u1_mps_state;
}
INC_BIN_COUNT(ps_cab_env);INC_DECISION_BINS(ps_cab_env);
u4_value++;
ps_bin_ctxt = p_ctxt_abs_level + (u4_ctx_inc >> 4);
}
while(u4_symbol && (u4_value < UCOFF_LEVEL));
ui_prefix = u4_value - 1 + u4_symbol;
}
if(ui_prefix == UCOFF_LEVEL)
{
UWORD32 ui16_sufS = 0;
UWORD32 u1_max_bins;
UWORD32 u4_value;
i2_abs_lvl = UCOFF_LEVEL;
/*inlining ih264d_decode_bypass_bins_unary begins*/
{
UWORD32 uc_bin;
UWORD32 bits_to_flush;
bits_to_flush = 0;
/*renormalize to ensure there 23 bits more in the u4_code_int_val_ofst*/
{
UWORD32 u4_clz, read_bits;
u4_clz = CLZ(u4_code_int_range);
FLUSHBITS(u4_offset, u4_clz)
NEXTBITS(read_bits, u4_offset, pu4_buffer, CABAC_BITS_TO_READ)
u4_code_int_range = u4_code_int_range << u4_clz;
u4_code_int_val_ofst = (u4_code_int_val_ofst
<< u4_clz) | read_bits;
}
do
{
bits_to_flush++;
u4_code_int_range = u4_code_int_range >> 1;
if(u4_code_int_val_ofst >= u4_code_int_range)
{
/* S=1 */
uc_bin = 1;
u4_code_int_val_ofst -= u4_code_int_range;
}
else
{
/* S=0 */
uc_bin = 0;
}
INC_BIN_COUNT(
ps_cab_env);INC_BYPASS_BINS(ps_cab_env);
}
while(uc_bin && (bits_to_flush < CABAC_BITS_TO_READ));
u4_value = (bits_to_flush - 1);
}
/*inlining ih264d_decode_bypass_bins_unary ends*/
ui16_sufS = (1 << u4_value);
u1_max_bins = u4_value;
if(u4_value > 0)
{
/*inline bypassbins_flc begins*/
if(u4_value > 10)
{
UWORD32 u4_clz, read_bits;
u4_clz = CLZ(u4_code_int_range);
FLUSHBITS(u4_offset, u4_clz)
NEXTBITS(read_bits, u4_offset, pu4_buffer, CABAC_BITS_TO_READ)
u4_code_int_range = u4_code_int_range << u4_clz;
u4_code_int_val_ofst = (u4_code_int_val_ofst
<< u4_clz) | read_bits;
}
{
UWORD32 ui_bins;
UWORD32 uc_bin;
UWORD32 bits_to_flush;
ui_bins = 0;
bits_to_flush = 0;
do
{
bits_to_flush++;
u4_code_int_range = u4_code_int_range >> 1;
if(u4_code_int_val_ofst
>= u4_code_int_range)
{
/* S=1 */
uc_bin = 1;
u4_code_int_val_ofst -=
u4_code_int_range;
}
else
{
/* S=0 */
uc_bin = 0;
}
INC_BIN_COUNT(
ps_cab_env);INC_BYPASS_BINS(ps_cab_env);
ui_bins = ((ui_bins << 1) | uc_bin);
}
while(bits_to_flush < u1_max_bins);
u4_value = ui_bins;
}
/*inline bypassbins_flc ends*/
}
//Value of K
ui16_sufS += u4_value;
i2_abs_lvl += ui16_sufS;
}
else
i2_abs_lvl = 1 + ui_prefix;
if(i2_abs_lvl > 1)
{
u1_abs_level_gt1++;
}
if(!u1_abs_level_gt1)
{
u1_abs_level_equal1++;
u4_ctx_inc = (5 << 4) + MIN(u1_abs_level_equal1, 4);
}
else
u4_ctx_inc = (5 + MIN(u1_abs_level_gt1, 4)) << 4;
/*u4_ctx_inc = g_table_temp[u1_abs_level_gt1][u1_abs_level_equal1];*/
/* encode coeff_sign_flag[i] */
{
u4_code_int_range = u4_code_int_range >> 1;
if(u4_code_int_val_ofst >= (u4_code_int_range))
{
/* S=1 */
u4_code_int_val_ofst -= u4_code_int_range;
i2_abs_lvl = (-i2_abs_lvl);
}
}
num_sig_coeffs--;
*pi2_coeff_data++ = i2_abs_lvl;
}
}
while(num_sig_coeffs > 0);
}
}
if(u4_coded_flag)
{
WORD32 offset;
offset = (UWORD8 *)pi2_coeff_data - (UWORD8 *)ps_tu_4x4;
offset = ALIGN4(offset);
ps_dec->pv_parse_tu_coeff_data = (void *)((UWORD8 *)ps_dec->pv_parse_tu_coeff_data + offset);
}
/*updating structures*/
ps_cab_env->u4_code_int_val_ofst = u4_code_int_val_ofst;
ps_cab_env->u4_code_int_range = u4_code_int_range;
ps_bitstrm->u4_ofst = u4_offset;
return (u4_coded_flag);
}
/*!
********************************************************************************
* \if Function name : ih264d_read_coeff8x8_cabac \endif
*
* \brief This function encodes residual_block_cabac as defined in 7.3.5.3.2.
when transform_8x8_flag = 1
*
* \return
* Returns the index of last significant coeff.
*
********************************************************************************
*/
void ih264d_read_coeff8x8_cabac(dec_bit_stream_t *ps_bitstrm,
dec_struct_t *ps_dec, /*!< pointer to access global variables*/
dec_mb_info_t *ps_cur_mb_info)
{
decoding_envirnoment_t *ps_cab_env = &ps_dec->s_cab_dec_env;
UWORD32 u4_offset, *pu4_buffer;
UWORD32 u4_code_int_range, u4_code_int_val_ofst;
/* High profile related declarations */
UWORD8 u1_field_coding_flag = ps_cur_mb_info->ps_curmb->u1_mb_fld;
const UWORD8 *pu1_lastcoeff_context_inc =
(UWORD8 *)gau1_ih264d_lastcoeff_context_inc;
const UWORD8 *pu1_sigcoeff_context_inc;
bin_ctxt_model_t *ps_ctxt_sig_coeff;
WORD32 num_sig_coeffs = 0;
tu_blk8x8_coeff_data_t *ps_tu_8x8;
WORD16 *pi2_coeff_data;
/*loading from strcuctures*/
ps_tu_8x8 = (tu_blk8x8_coeff_data_t *)ps_dec->pv_parse_tu_coeff_data;
ps_tu_8x8->au4_sig_coeff_map[0] = 0;
ps_tu_8x8->au4_sig_coeff_map[1] = 0;
pi2_coeff_data = &ps_tu_8x8->ai2_level[0];
if(!u1_field_coding_flag)
{
pu1_sigcoeff_context_inc =
(UWORD8 *)gau1_ih264d_sigcoeff_context_inc_frame;
/*******************************************************************/
/* last coefficient context is derived from significant coeff u4_flag */
/* only significant coefficient matrix need to be initialized */
/*******************************************************************/
ps_ctxt_sig_coeff = ps_dec->s_high_profile.ps_sigcoeff_8x8_frame;
}
else
{
pu1_sigcoeff_context_inc =
(UWORD8 *)gau1_ih264d_sigcoeff_context_inc_field;
/*******************************************************************/
/* last coefficient context is derived from significant coeff u4_flag */
/* only significant coefficient matrix need to be initialized */
/*******************************************************************/
ps_ctxt_sig_coeff = ps_dec->s_high_profile.ps_sigcoeff_8x8_field;
}
/*loading from strcuctures*/
u4_offset = ps_bitstrm->u4_ofst;
pu4_buffer = ps_bitstrm->pu4_buffer;
u4_code_int_range = ps_cab_env->u4_code_int_range;
u4_code_int_val_ofst = ps_cab_env->u4_code_int_val_ofst;
{
{
bin_ctxt_model_t *p_binCtxt_last, *p_binCtxt_last_org,
*p_ctxt_sig_coeff_org;
UWORD32 uc_last_coeff_idx;
UWORD32 uc_bin;
UWORD32 i;
i = 0;
uc_last_coeff_idx = 63;
p_binCtxt_last_org = ps_ctxt_sig_coeff
+ LAST_COEFF_CTXT_MINUS_SIG_COEFF_CTXT_8X8;
p_ctxt_sig_coeff_org = ps_ctxt_sig_coeff;
do
{
/*inilined DecodeDecision_onebin begins*/
{
UWORD32 u4_qnt_int_range, u4_int_range_lps;
UWORD32 u4_symbol, u1_mps_state;
UWORD32 table_lookup;
const UWORD32 *pu4_table =
(const UWORD32 *)ps_cab_env->cabac_table;
UWORD32 u4_clz;
u1_mps_state = (ps_ctxt_sig_coeff->u1_mps_state);
u4_clz = CLZ(u4_code_int_range);
u4_qnt_int_range = u4_code_int_range << u4_clz;
u4_qnt_int_range = (u4_qnt_int_range >> 29) & 0x3;
table_lookup = pu4_table[(u1_mps_state << 2)
+ u4_qnt_int_range];
u4_int_range_lps = table_lookup & 0xff;
u4_int_range_lps = u4_int_range_lps << (23 - u4_clz);
u4_code_int_range = u4_code_int_range - u4_int_range_lps;
u4_symbol = ((u1_mps_state >> 6) & 0x1);
u1_mps_state = (table_lookup >> 8) & 0x7F;
CHECK_IF_LPS(u4_code_int_range, u4_code_int_val_ofst,
u4_symbol, u4_int_range_lps, u1_mps_state,
table_lookup)
if(u4_code_int_range < ONE_RIGHT_SHIFTED_BY_14)
{
UWORD32 read_bits, u4_clz;
u4_clz = CLZ(u4_code_int_range);
NEXTBITS(read_bits, (u4_offset + 23), pu4_buffer,
u4_clz)
FLUSHBITS(u4_offset, (u4_clz))
u4_code_int_range = u4_code_int_range << u4_clz;
u4_code_int_val_ofst = (u4_code_int_val_ofst << u4_clz)
| read_bits;
}
ps_ctxt_sig_coeff->u1_mps_state = u1_mps_state;
uc_bin = u4_symbol;
}
/*incrementing pointer to point to the context of the next bin*/
ps_ctxt_sig_coeff = p_ctxt_sig_coeff_org
+ pu1_sigcoeff_context_inc[i + 1];
/*inilined DecodeDecision_onebin ends*/
if(uc_bin)
{
num_sig_coeffs++;
SET_BIT(ps_tu_8x8->au4_sig_coeff_map[i>31], (i > 31 ? i - 32:i));
p_binCtxt_last = p_binCtxt_last_org
+ pu1_lastcoeff_context_inc[i];
/*inilined DecodeDecision_onebin begins*/
{
UWORD32 u4_qnt_int_range, u4_int_range_lps;
UWORD32 u4_symbol, u1_mps_state;
UWORD32 table_lookup;
const UWORD32 *pu4_table =
(const UWORD32 *)ps_cab_env->cabac_table;
UWORD32 u4_clz;
u1_mps_state = (p_binCtxt_last->u1_mps_state);
u4_clz = CLZ(u4_code_int_range);
u4_qnt_int_range = u4_code_int_range << u4_clz;
u4_qnt_int_range = (u4_qnt_int_range >> 29)
& 0x3;
table_lookup = pu4_table[(u1_mps_state << 2)
+ u4_qnt_int_range];
u4_int_range_lps = table_lookup & 0xff;
u4_int_range_lps = u4_int_range_lps
<< (23 - u4_clz);
u4_code_int_range = u4_code_int_range
- u4_int_range_lps;
u4_symbol = ((u1_mps_state >> 6) & 0x1);
u1_mps_state = (table_lookup >> 8) & 0x7F;
CHECK_IF_LPS(u4_code_int_range, u4_code_int_val_ofst,
u4_symbol, u4_int_range_lps,
u1_mps_state, table_lookup)
p_binCtxt_last->u1_mps_state = u1_mps_state;
uc_bin = u4_symbol;
}
/*inilined DecodeDecision_onebin ends*/
if(uc_bin == 1)
goto label_read_levels;
}
i = i + 1;
}
while(i < uc_last_coeff_idx);
num_sig_coeffs++;
SET_BIT(ps_tu_8x8->au4_sig_coeff_map[i>31], (i > 31 ? i - 32:i));
label_read_levels: ;
}
/// VALUE of No of Coeff in BLOCK = i + 1 for second case else i;
/* Decode coeff_abs_level_minus1 and coeff_sign_flag */
{
WORD32 i2_abs_lvl;
UWORD32 u1_abs_level_equal1 = 1, u1_abs_level_gt1 = 0;
UWORD32 u4_ctx_inc;
UWORD32 ui_prefix;
bin_ctxt_model_t *p_ctxt_abs_level;
p_ctxt_abs_level =
ps_dec->p_coeff_abs_level_minus1_t[LUMA_8X8_CTXCAT];
u4_ctx_inc = ((0x51));
/*****************************************************/
/* Main Loop runs for no. of Significant coefficient */
/*****************************************************/
do
{
{
/*****************************************************/
/* inilining a modified ih264d_decode_bins_unary */
/*****************************************************/
{
UWORD32 u4_value;
UWORD32 u4_symbol;
bin_ctxt_model_t *ps_bin_ctxt;
UWORD32 u4_ctx_Inc;
u4_value = 0;
u4_ctx_Inc = u4_ctx_inc & 0xf;
ps_bin_ctxt = p_ctxt_abs_level + u4_ctx_Inc;
do
{
{
UWORD32 u4_qnt_int_range,
u4_int_range_lps;
UWORD32 u1_mps_state;
UWORD32 table_lookup;
const UWORD32 *pu4_table =
(const UWORD32 *)ps_cab_env->cabac_table;
UWORD32 u4_clz;
u1_mps_state = (ps_bin_ctxt->u1_mps_state);
u4_clz = CLZ(u4_code_int_range);
u4_qnt_int_range = u4_code_int_range
<< u4_clz;
u4_qnt_int_range = (u4_qnt_int_range
>> 29) & 0x3;
table_lookup = pu4_table[(u1_mps_state << 2)
+ u4_qnt_int_range];
u4_int_range_lps = table_lookup & 0xff;
u4_int_range_lps = u4_int_range_lps
<< (23 - u4_clz);
u4_code_int_range = u4_code_int_range
- u4_int_range_lps;
u4_symbol = ((u1_mps_state >> 6) & 0x1);
u1_mps_state = (table_lookup >> 8) & 0x7F;
CHECK_IF_LPS(u4_code_int_range,
u4_code_int_val_ofst, u4_symbol,
u4_int_range_lps, u1_mps_state,
table_lookup)
if(u4_code_int_range < ONE_RIGHT_SHIFTED_BY_9)
{
RENORM_RANGE_OFFSET(u4_code_int_range,
u4_code_int_val_ofst,
u4_offset, pu4_buffer)
}
ps_bin_ctxt->u1_mps_state = u1_mps_state;
}
u4_value++;
ps_bin_ctxt = p_ctxt_abs_level + (u4_ctx_inc >> 4);
}
while(u4_symbol && (u4_value < UCOFF_LEVEL));
ui_prefix = u4_value - 1 + u4_symbol;
}
if(ui_prefix == UCOFF_LEVEL)
{
UWORD32 ui16_sufS = 0;
UWORD32 u1_max_bins;
UWORD32 u4_value;
i2_abs_lvl = UCOFF_LEVEL;
/*inlining ih264d_decode_bypass_bins_unary begins*/
{
UWORD32 uc_bin;
UWORD32 bits_to_flush;
bits_to_flush = 0;
/*renormalize to ensure there 23 bits more in the u4_code_int_val_ofst*/
{
UWORD32 u4_clz, read_bits;
u4_clz = CLZ(u4_code_int_range);
FLUSHBITS(u4_offset, u4_clz)
NEXTBITS(read_bits, u4_offset, pu4_buffer, CABAC_BITS_TO_READ)
u4_code_int_range = u4_code_int_range << u4_clz;
u4_code_int_val_ofst = (u4_code_int_val_ofst
<< u4_clz) | read_bits;
}
do
{
bits_to_flush++;
u4_code_int_range = u4_code_int_range >> 1;
if(u4_code_int_val_ofst >= u4_code_int_range)
{
/* S=1 */
uc_bin = 1;
u4_code_int_val_ofst -= u4_code_int_range;
}
else
{
/* S=0 */
uc_bin = 0;
}
}
while(uc_bin && (bits_to_flush < CABAC_BITS_TO_READ));
u4_value = (bits_to_flush - 1);
}
/*inlining ih264d_decode_bypass_bins_unary ends*/
ui16_sufS = (1 << u4_value);
u1_max_bins = u4_value;
if(u4_value > 0)
{
/*inline bypassbins_flc begins*/
if(u4_value > 10)
{
UWORD32 u4_clz, read_bits;
u4_clz = CLZ(u4_code_int_range);
FLUSHBITS(u4_offset, u4_clz)
NEXTBITS(read_bits, u4_offset, pu4_buffer, CABAC_BITS_TO_READ)
u4_code_int_range = u4_code_int_range << u4_clz;
u4_code_int_val_ofst = (u4_code_int_val_ofst
<< u4_clz) | read_bits;
}
{
UWORD32 ui_bins;
UWORD32 uc_bin;
UWORD32 bits_to_flush;
ui_bins = 0;
bits_to_flush = 0;
do
{
bits_to_flush++;
u4_code_int_range = u4_code_int_range >> 1;
if(u4_code_int_val_ofst
>= u4_code_int_range)
{
/* S=1 */
uc_bin = 1;
u4_code_int_val_ofst -=
u4_code_int_range;
}
else
{
/* S=0 */
uc_bin = 0;
}
ui_bins = ((ui_bins << 1) | uc_bin);
}
while(bits_to_flush < u1_max_bins);
u4_value = ui_bins;
}
/*inline bypassbins_flc ends*/
}
//Value of K
ui16_sufS += u4_value;
i2_abs_lvl += (WORD32)ui16_sufS;
}
else
{
i2_abs_lvl = 1 + ui_prefix;
}
if(i2_abs_lvl > 1)
{
u1_abs_level_gt1++;
}
if(!u1_abs_level_gt1)
{
u1_abs_level_equal1++;
u4_ctx_inc = (5 << 4) + MIN(u1_abs_level_equal1, 4);
}
else
{
u4_ctx_inc = (5 + MIN(u1_abs_level_gt1, 4)) << 4;
}
/*u4_ctx_inc = g_table_temp[u1_abs_level_gt1][u1_abs_level_equal1];*/
/* encode coeff_sign_flag[i] */
{
u4_code_int_range = u4_code_int_range >> 1;
if(u4_code_int_val_ofst >= (u4_code_int_range))
{
/* S=1 */
u4_code_int_val_ofst -= u4_code_int_range;
i2_abs_lvl = (-i2_abs_lvl);
}
}
*pi2_coeff_data++ = i2_abs_lvl;
num_sig_coeffs--;
}
}
while(num_sig_coeffs > 0);
}
}
{
WORD32 offset;
offset = (UWORD8 *)pi2_coeff_data - (UWORD8 *)ps_tu_8x8;
offset = ALIGN4(offset);
ps_dec->pv_parse_tu_coeff_data = (void *)((UWORD8 *)ps_dec->pv_parse_tu_coeff_data + offset);
}
/*updating structures*/
ps_cab_env->u4_code_int_val_ofst = u4_code_int_val_ofst;
ps_cab_env->u4_code_int_range = u4_code_int_range;
ps_bitstrm->u4_ofst = u4_offset;
}
/*****************************************************************************/
/* */
/* Function Name : ih264d_cabac_parse_8x8block */
/* */
/* Description : This function does the residual parsing of 4 subblocks */
/* in a 8x8 block. */
/* */
/* Inputs : pi2_coeff_block : pointer to residual block where */
/* decoded and inverse scan coefficients are updated */
/* */
/* u4_sub_block_strd : indicates the number of sublocks */
/* in a row. It is 4 for luma and 2 for chroma. */
/* */
/* u4_ctx_cat : inidicates context category for residual */
/* decoding. */
/* */
/* ps_dec : pointer to Decstruct (decoder context) */
/* */
/* pu1_top_nnz : top nnz pointer */
/* */
/* pu1_left_nnz : left nnz pointer */
/* */
/* Globals : No */
/* Processing : Parsing for four subblocks in unrolled, top and left nnz */
/* are updated on the fly. csbp is set in accordance to */
/* decoded numcoeff for the subblock index in raster order */
/* */
/* Outputs : The updated residue buffer, nnzs and csbp current block */
/* */
/* Returns : Returns the coded sub block pattern csbp for the block */
/* */
/* Issues : <List any issues or problems with this function> */
/* */
/* Revision History: */
/* */
/* DD MM YYYY Author(s) Changes (Describe the changes made) */
/* 09 10 2008 Jay Draft */
/* */
/*****************************************************************************/
UWORD32 ih264d_cabac_parse_8x8block(WORD16 *pi2_coeff_block,
UWORD32 u4_sub_block_strd,
UWORD32 u4_ctx_cat,
dec_struct_t * ps_dec,
UWORD8 *pu1_top_nnz,
UWORD8 *pu1_left_nnz)
{
UWORD32 u4_ctxinc, u4_subblock_coded;
UWORD32 u4_top0, u4_top1;
UWORD32 u4_csbp = 0;
UWORD32 u4_idx = 0;
dec_bit_stream_t * const ps_bitstrm = ps_dec->ps_bitstrm;
bin_ctxt_model_t * const ps_cbf = ps_dec->p_cbf_t[u4_ctx_cat];
bin_ctxt_model_t *ps_src_bin_ctxt;
bin_ctxt_model_t * const ps_sig_coeff_flag =
ps_dec->p_significant_coeff_flag_t[u4_ctx_cat];
UWORD8 *pu1_inv_scan = ps_dec->pu1_inv_scan;
/*------------------------------------------------------*/
/* Residual 4x4 decoding: SubBlock 0 */
/*------------------------------------------------------*/
u4_ctxinc = ((!!pu1_top_nnz[0]) << 1) + (!!pu1_left_nnz[0]);
ps_src_bin_ctxt = ps_cbf + u4_ctxinc;
u4_top0 = ih264d_read_coeff4x4_cabac( ps_bitstrm,
u4_ctx_cat, ps_sig_coeff_flag, ps_dec,
ps_src_bin_ctxt);
INSERT_BIT(u4_csbp, u4_idx, u4_top0);
/*------------------------------------------------------*/
/* Residual 4x4 decoding: SubBlock 1 */
/*------------------------------------------------------*/
u4_idx++;
pi2_coeff_block += NUM_COEFFS_IN_4x4BLK;
u4_ctxinc = ((!!pu1_top_nnz[1]) << 1) + u4_top0;
ps_src_bin_ctxt = ps_cbf + u4_ctxinc;
u4_top1 = ih264d_read_coeff4x4_cabac(ps_bitstrm,
u4_ctx_cat, ps_sig_coeff_flag, ps_dec,
ps_src_bin_ctxt);
INSERT_BIT(u4_csbp, u4_idx, u4_top1);
pu1_left_nnz[0] = u4_top1;
/*------------------------------------------------------*/
/* Residual 4x4 decoding: SubBlock 2 */
/*------------------------------------------------------*/
u4_idx += (u4_sub_block_strd - 1);
pi2_coeff_block += ((u4_sub_block_strd - 1) * NUM_COEFFS_IN_4x4BLK);
u4_ctxinc = (u4_top0 << 1) + (!!pu1_left_nnz[1]);
ps_src_bin_ctxt = ps_cbf + u4_ctxinc;
u4_subblock_coded = ih264d_read_coeff4x4_cabac(ps_bitstrm, u4_ctx_cat,
ps_sig_coeff_flag, ps_dec,
ps_src_bin_ctxt);
INSERT_BIT(u4_csbp, u4_idx, u4_subblock_coded);
pu1_top_nnz[0] = u4_subblock_coded;
/*------------------------------------------------------*/
/* Residual 4x4 decoding: SubBlock 3 */
/*------------------------------------------------------*/
u4_idx++;
pi2_coeff_block += NUM_COEFFS_IN_4x4BLK;
u4_ctxinc = (u4_top1 << 1) + u4_subblock_coded;
ps_src_bin_ctxt = ps_cbf + u4_ctxinc;
u4_subblock_coded = ih264d_read_coeff4x4_cabac(ps_bitstrm, u4_ctx_cat,
ps_sig_coeff_flag, ps_dec,
ps_src_bin_ctxt);
INSERT_BIT(u4_csbp, u4_idx, u4_subblock_coded);
pu1_top_nnz[1] = pu1_left_nnz[1] = u4_subblock_coded;
return (u4_csbp);
}
/*!
**************************************************************************
* \if Function name : ih264d_parse_residual4x4_cabac \endif
*
* \brief
* This function parses CABAC syntax of a Luma and Chroma AC Residuals.
*
* \return
* 0 on Success and Error code otherwise
**************************************************************************
*/
WORD32 ih264d_parse_residual4x4_cabac(dec_struct_t * ps_dec,
dec_mb_info_t *ps_cur_mb_info,
UWORD8 u1_offset)
{
UWORD8 u1_cbp = ps_cur_mb_info->u1_cbp;
UWORD16 ui16_csbp = 0;
WORD16 *pi2_residual_buf;
UWORD8 uc_ctx_cat;
UWORD8 *pu1_top_nnz = ps_cur_mb_info->ps_curmb->pu1_nnz_y;
UWORD8 *pu1_left_nnz = ps_dec->pu1_left_nnz_y;
UWORD8 *pu1_top_nnz_uv = ps_cur_mb_info->ps_curmb->pu1_nnz_uv;
ctxt_inc_mb_info_t *p_curr_ctxt = ps_dec->ps_curr_ctxt_mb_info;
ctxt_inc_mb_info_t *ps_top_ctxt = ps_dec->p_top_ctxt_mb_info;
dec_bit_stream_t * const ps_bitstrm = ps_dec->ps_bitstrm;
UWORD32 u4_nbr_avail = ps_dec->u1_mb_ngbr_availablity;
WORD16 *pi2_coeff_block = NULL;
bin_ctxt_model_t *ps_src_bin_ctxt;
UWORD8 u1_top_dc_csbp = (ps_top_ctxt->u1_yuv_dc_csbp) >> 1;
UWORD8 u1_left_dc_csbp = (ps_dec->pu1_left_yuv_dc_csbp[0]) >> 1;
if(!(u4_nbr_avail & TOP_MB_AVAILABLE_MASK))
{
if(p_curr_ctxt->u1_mb_type & CAB_INTRA_MASK)
{
*(UWORD32 *)pu1_top_nnz = 0;
u1_top_dc_csbp = 0;
*(UWORD32 *)pu1_top_nnz_uv = 0;
}
else
{
*(UWORD32 *)pu1_top_nnz = 0x01010101;
u1_top_dc_csbp = 0x3;
*(UWORD32 *)pu1_top_nnz_uv = 0x01010101;
}
}
else
{
UWORD32 *pu4_buf;
UWORD8 *pu1_buf;
pu1_buf = ps_cur_mb_info->ps_top_mb->pu1_nnz_y;
pu4_buf = (UWORD32 *)pu1_buf;
*(UWORD32 *)(pu1_top_nnz) = *pu4_buf;
pu1_buf = ps_cur_mb_info->ps_top_mb->pu1_nnz_uv;
pu4_buf = (UWORD32 *)pu1_buf;
*(UWORD32 *)(pu1_top_nnz_uv) = *pu4_buf;
}
if(!(u4_nbr_avail & LEFT_MB_AVAILABLE_MASK))
{
if(p_curr_ctxt->u1_mb_type & CAB_INTRA_MASK)
{
UWORD32 *pu4_buf;
UWORD8 *pu1_buf;
*(UWORD32 *)pu1_left_nnz = 0;
u1_left_dc_csbp = 0;
pu1_buf = ps_dec->pu1_left_nnz_uv;
pu4_buf = (UWORD32 *)pu1_buf;
*pu4_buf = 0;
}
else
{
UWORD32 *pu4_buf;
UWORD8 *pu1_buf;
*(UWORD32 *)pu1_left_nnz = 0x01010101;
u1_left_dc_csbp = 0x3;
pu1_buf = ps_dec->pu1_left_nnz_uv;
pu4_buf = (UWORD32 *)pu1_buf;
*pu4_buf = 0x01010101;
}
}
uc_ctx_cat = u1_offset ? LUMA_AC_CTXCAT : LUMA_4X4_CTXCAT;
ps_cur_mb_info->u1_qp_div6 = ps_dec->u1_qp_y_div6;
ps_cur_mb_info->u1_qpc_div6 = ps_dec->u1_qp_u_div6;
ps_cur_mb_info->u1_qp_rem6 = ps_dec->u1_qp_y_rem6;
ps_cur_mb_info->u1_qpc_rem6 = ps_dec->u1_qp_u_rem6;
// CHECK_THIS
ps_cur_mb_info->u1_qpcr_div6 = ps_dec->u1_qp_v_div6;
ps_cur_mb_info->u1_qpcr_rem6 = ps_dec->u1_qp_v_rem6;
if(u1_cbp & 0x0f)
{
if(ps_cur_mb_info->u1_tran_form8x8 == 0)
{
/*******************************************************************/
/* Block 0 residual decoding, check cbp and proceed (subblock = 0) */
/*******************************************************************/
if(!(u1_cbp & 0x1))
{
*(UWORD16 *)(pu1_top_nnz) = 0;
*(UWORD16 *)(pu1_left_nnz) = 0;
}
else
{
ui16_csbp = ih264d_cabac_parse_8x8block(pi2_coeff_block, 4,
uc_ctx_cat, ps_dec,
pu1_top_nnz,
pu1_left_nnz);
}
/*******************************************************************/
/* Block 1 residual decoding, check cbp and proceed (subblock = 2) */
/*******************************************************************/
pi2_coeff_block += (2 * NUM_COEFFS_IN_4x4BLK);
if(!(u1_cbp & 0x2))
{
*(UWORD16 *)(pu1_top_nnz + 2) = 0;
*(UWORD16 *)(pu1_left_nnz) = 0;
}
else
{
UWORD32 u4_temp = ih264d_cabac_parse_8x8block(pi2_coeff_block,
4, uc_ctx_cat,
ps_dec,
(pu1_top_nnz + 2),
pu1_left_nnz);
ui16_csbp |= (u4_temp << 2);
}
/*******************************************************************/
/* Block 2 residual decoding, check cbp and proceed (subblock = 8) */
/*******************************************************************/
pi2_coeff_block += (6 * NUM_COEFFS_IN_4x4BLK);
if(!(u1_cbp & 0x4))
{
*(UWORD16 *)(pu1_top_nnz) = 0;
*(UWORD16 *)(pu1_left_nnz + 2) = 0;
}
else
{
UWORD32 u4_temp = ih264d_cabac_parse_8x8block(
pi2_coeff_block, 4, uc_ctx_cat, ps_dec,
pu1_top_nnz, (pu1_left_nnz + 2));
ui16_csbp |= (u4_temp << 8);
}
/*******************************************************************/
/* Block 3 residual decoding, check cbp and proceed (subblock = 10)*/
/*******************************************************************/
pi2_coeff_block += (2 * NUM_COEFFS_IN_4x4BLK);
if(!(u1_cbp & 0x8))
{
*(UWORD16 *)(pu1_top_nnz + 2) = 0;
*(UWORD16 *)(pu1_left_nnz + 2) = 0;
}
else
{
UWORD32 u4_temp = ih264d_cabac_parse_8x8block(
pi2_coeff_block, 4, uc_ctx_cat, ps_dec,
(pu1_top_nnz + 2), (pu1_left_nnz + 2));
ui16_csbp |= (u4_temp << 10);
}
}
else
{
ui16_csbp = 0;
/*******************************************************************/
/* Block 0 residual decoding, check cbp and proceed (subblock = 0) */
/*******************************************************************/
if(!(u1_cbp & 0x1))
{
*(UWORD16 *)(pu1_top_nnz) = 0;
*(UWORD16 *)(pu1_left_nnz) = 0;
}
else
{
dec_bit_stream_t * const ps_bitstrm = ps_dec->ps_bitstrm;
ih264d_read_coeff8x8_cabac( ps_bitstrm,
ps_dec, ps_cur_mb_info);
pu1_left_nnz[0] = 1;
pu1_left_nnz[1] = 1;
pu1_top_nnz[0] = 1;
pu1_top_nnz[1] = 1;
/* added to be used by BS computation module */
ui16_csbp |= 0x0033;
}
/*******************************************************************/
/* Block 1 residual decoding, check cbp and proceed (subblock = 2) */
/*******************************************************************/
pi2_coeff_block += 64;
if(!(u1_cbp & 0x2))
{
*(UWORD16 *)(pu1_top_nnz + 2) = 0;
*(UWORD16 *)(pu1_left_nnz) = 0;
}
else
{
dec_bit_stream_t * const ps_bitstrm = ps_dec->ps_bitstrm;
ih264d_read_coeff8x8_cabac(ps_bitstrm,
ps_dec, ps_cur_mb_info);
pu1_left_nnz[0] = 1;
pu1_left_nnz[1] = 1;
pu1_top_nnz[2] = 1;
pu1_top_nnz[3] = 1;
/* added to be used by BS computation module */
ui16_csbp |= 0x00CC;
}
/*******************************************************************/
/* Block 2 residual decoding, check cbp and proceed (subblock = 8) */
/*******************************************************************/
pi2_coeff_block += 64;
if(!(u1_cbp & 0x4))
{
*(UWORD16 *)(pu1_top_nnz) = 0;
*(UWORD16 *)(pu1_left_nnz + 2) = 0;
}
else
{
dec_bit_stream_t * const ps_bitstrm = ps_dec->ps_bitstrm;
ih264d_read_coeff8x8_cabac(ps_bitstrm,
ps_dec, ps_cur_mb_info);
pu1_left_nnz[2] = 1;
pu1_left_nnz[3] = 1;
pu1_top_nnz[0] = 1;
pu1_top_nnz[1] = 1;
/* added to be used by BS computation module */
ui16_csbp |= 0x3300;
}
/*******************************************************************/
/* Block 3 residual decoding, check cbp and proceed (subblock = 10)*/
/*******************************************************************/
pi2_coeff_block += 64;
if(!(u1_cbp & 0x8))
{
*(UWORD16 *)(pu1_top_nnz + 2) = 0;
*(UWORD16 *)(pu1_left_nnz + 2) = 0;
}
else
{
dec_bit_stream_t * const ps_bitstrm = ps_dec->ps_bitstrm;
ih264d_read_coeff8x8_cabac(ps_bitstrm,
ps_dec, ps_cur_mb_info);
pu1_left_nnz[2] = 1;
pu1_left_nnz[3] = 1;
pu1_top_nnz[2] = 1;
pu1_top_nnz[3] = 1;
/* added to be used by BS computation module */
ui16_csbp |= 0xCC00;
}
}
}
else
{
*(UWORD32 *)(pu1_top_nnz) = 0;
*(UWORD32 *)(pu1_left_nnz) = 0;
}
/*--------------------------------------------------------------------*/
/* Store the last row of N values to top row */
/*--------------------------------------------------------------------*/
ps_cur_mb_info->u2_luma_csbp = ui16_csbp;
ps_cur_mb_info->ps_curmb->u2_luma_csbp = ui16_csbp;
{
WORD8 i;
UWORD16 u2_chroma_csbp = 0;
ps_cur_mb_info->u2_chroma_csbp = 0;
u1_cbp >>= 4;
pu1_top_nnz = pu1_top_nnz_uv;
pu1_left_nnz = ps_dec->pu1_left_nnz_uv;
/*--------------------------------------------------------------------*/
/* if Chroma Component not present OR no ac values present */
/* Set the values of N to zero */
/*--------------------------------------------------------------------*/
if(u1_cbp == CBPC_ALLZERO)
{
ps_dec->pu1_left_yuv_dc_csbp[0] &= 0x1;
*(UWORD32 *)(pu1_top_nnz) = 0;
*(UWORD32 *)(pu1_left_nnz) = 0;
p_curr_ctxt->u1_yuv_dc_csbp &= 0x1;
return (0);
}
/*--------------------------------------------------------------------*/
/* Decode Chroma DC values */
/*--------------------------------------------------------------------*/
for(i = 0; i < 2; i++)
{
UWORD8 uc_a = 1, uc_b = 1;
UWORD32 u4_ctx_inc;
UWORD8 uc_codedBlockFlag;
UWORD8 pu1_inv_scan[4] =
{ 0, 1, 2, 3 };
WORD32 u4_scale;
WORD32 i4_mb_inter_inc;
tu_sblk4x4_coeff_data_t *ps_tu_4x4 =
(tu_sblk4x4_coeff_data_t *)ps_dec->pv_parse_tu_coeff_data;
WORD16 *pi2_coeff_data =
(WORD16 *)ps_dec->pv_parse_tu_coeff_data;
WORD16 ai2_dc_coef[4];
INC_SYM_COUNT(&(ps_dec->s_cab_dec_env));
u4_scale = (i) ?
(ps_dec->pu2_quant_scale_v[0]
<< ps_dec->u1_qp_v_div6) :
(ps_dec->pu2_quant_scale_u[0]
<< ps_dec->u1_qp_u_div6);
/*--------------------------------------------------------------------*/
/* Decode Bitstream to get the DC coeff */
/*--------------------------------------------------------------------*/
uc_a = (u1_left_dc_csbp >> i) & 0x01;
uc_b = (u1_top_dc_csbp >> i) & 0x01;
u4_ctx_inc = (uc_a + (uc_b << 1));
ps_src_bin_ctxt = (ps_dec->p_cbf_t[CHROMA_DC_CTXCAT]) + u4_ctx_inc;
uc_codedBlockFlag =
ih264d_read_coeff4x4_cabac(ps_bitstrm,
CHROMA_DC_CTXCAT,
ps_dec->p_significant_coeff_flag_t[CHROMA_DC_CTXCAT],
ps_dec, ps_src_bin_ctxt);
i4_mb_inter_inc = (!((ps_cur_mb_info->ps_curmb->u1_mb_type == I_4x4_MB)
|| (ps_cur_mb_info->ps_curmb->u1_mb_type == I_16x16_MB)))
* 3;
if(ps_dec->s_high_profile.u1_scaling_present)
{
u4_scale *=
ps_dec->s_high_profile.i2_scalinglist4x4[i4_mb_inter_inc
+ 1 + i][0];
}
else
{
u4_scale <<= 4;
}
if(uc_codedBlockFlag)
{
WORD32 i_z0, i_z1, i_z2, i_z3;
WORD32 *pi4_scale;
SET_BIT(u1_top_dc_csbp, i);
SET_BIT(u1_left_dc_csbp, i);
ai2_dc_coef[0] = 0;
ai2_dc_coef[1] = 0;
ai2_dc_coef[2] = 0;
ai2_dc_coef[3] = 0;
ih264d_unpack_coeff4x4_dc_4x4blk(ps_tu_4x4,
ai2_dc_coef,
pu1_inv_scan);
i_z0 = (ai2_dc_coef[0] + ai2_dc_coef[2]);
i_z1 = (ai2_dc_coef[0] - ai2_dc_coef[2]);
i_z2 = (ai2_dc_coef[1] - ai2_dc_coef[3]);
i_z3 = (ai2_dc_coef[1] + ai2_dc_coef[3]);
/*-----------------------------------------------------------*/
/* Scaling and storing the values back */
/*-----------------------------------------------------------*/
*pi2_coeff_data++ = ((i_z0 + i_z3) * u4_scale) >> 5;
*pi2_coeff_data++ = ((i_z0 - i_z3) * u4_scale) >> 5;
*pi2_coeff_data++ = ((i_z1 + i_z2) * u4_scale) >> 5;
*pi2_coeff_data++ = ((i_z1 - i_z2) * u4_scale) >> 5;
ps_dec->pv_parse_tu_coeff_data = (void *)pi2_coeff_data;
SET_BIT(ps_cur_mb_info->u1_yuv_dc_block_flag,(i+1));
}
else
{
CLEARBIT(u1_top_dc_csbp, i);
CLEARBIT(u1_left_dc_csbp, i);
}
}
/*********************************************************************/
/* Update the DC csbp */
/*********************************************************************/
ps_dec->pu1_left_yuv_dc_csbp[0] &= 0x1;
p_curr_ctxt->u1_yuv_dc_csbp &= 0x1;
ps_dec->pu1_left_yuv_dc_csbp[0] |= (u1_left_dc_csbp << 1);
p_curr_ctxt->u1_yuv_dc_csbp |= (u1_top_dc_csbp << 1);
if(u1_cbp == CBPC_ACZERO)
{
*(UWORD32 *)(pu1_top_nnz) = 0;
*(UWORD32 *)(pu1_left_nnz) = 0;
return (0);
}
/*--------------------------------------------------------------------*/
/* Decode Chroma AC values */
/*--------------------------------------------------------------------*/
{
UWORD32 u4_temp;
/*****************************************************************/
/* U Block residual decoding, check cbp and proceed (subblock=0)*/
/*****************************************************************/
u2_chroma_csbp = ih264d_cabac_parse_8x8block(pi2_coeff_block, 2,
CHROMA_AC_CTXCAT,
ps_dec, pu1_top_nnz,
pu1_left_nnz);
pi2_coeff_block += MB_CHROM_SIZE;
/*****************************************************************/
/* V Block residual decoding, check cbp and proceed (subblock=1)*/
/*****************************************************************/
u4_temp = ih264d_cabac_parse_8x8block(pi2_coeff_block, 2,
CHROMA_AC_CTXCAT,
ps_dec, (pu1_top_nnz + 2),
(pu1_left_nnz + 2));
u2_chroma_csbp |= (u4_temp << 4);
}
/*********************************************************************/
/* Update the AC csbp */
/*********************************************************************/
ps_cur_mb_info->u2_chroma_csbp = u2_chroma_csbp;
}
return (0);
}