Decoder loops refactoring
Eliminated some mb branches along with other code cleanups. This is part of an ongoing effort to remove cut/paste code in the decoder. Change-Id: Ifabb0f67cafa6922b5a0e89a0d03a9b34e9e5752
This commit is contained in:
@@ -93,13 +93,14 @@ void mb_init_dequantizer(VP8D_COMP *pbi, MACROBLOCKD *xd)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void decode_macroblock(VP8D_COMP *pbi, MACROBLOCKD *xd,
|
static void decode_macroblock(VP8D_COMP *pbi, MACROBLOCKD *xd,
|
||||||
unsigned int mb_idx)
|
unsigned int mb_idx)
|
||||||
{
|
{
|
||||||
MB_PREDICTION_MODE mode;
|
MB_PREDICTION_MODE mode;
|
||||||
int i;
|
int i;
|
||||||
|
#if CONFIG_ERROR_CONCEALMENT
|
||||||
int corruption_detected = 0;
|
int corruption_detected = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
if (xd->mode_info_context->mbmi.mb_skip_coeff)
|
if (xd->mode_info_context->mbmi.mb_skip_coeff)
|
||||||
{
|
{
|
||||||
@@ -316,25 +317,68 @@ static int get_delta_q(vp8_reader *bc, int prev, int *q_update)
|
|||||||
FILE *vpxlog = 0;
|
FILE *vpxlog = 0;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
static void decode_mb_rows(VP8D_COMP *pbi)
|
||||||
|
|
||||||
static void
|
|
||||||
decode_mb_row(VP8D_COMP *pbi, VP8_COMMON *pc, int mb_row, MACROBLOCKD *xd)
|
|
||||||
{
|
{
|
||||||
int recon_yoffset, recon_uvoffset;
|
VP8_COMMON *const pc = & pbi->common;
|
||||||
int mb_col;
|
MACROBLOCKD *const xd = & pbi->mb;
|
||||||
int ref_fb_idx = pc->lst_fb_idx;
|
|
||||||
int dst_fb_idx = pc->new_fb_idx;
|
int ibc = 0;
|
||||||
int recon_y_stride = pc->yv12_fb[ref_fb_idx].y_stride;
|
int num_part = 1 << pc->multi_token_partition;
|
||||||
int recon_uv_stride = pc->yv12_fb[ref_fb_idx].uv_stride;
|
|
||||||
|
int recon_yoffset, recon_uvoffset;
|
||||||
|
int mb_row, mb_col;
|
||||||
|
int mb_idx = 0;
|
||||||
|
int dst_fb_idx = pc->new_fb_idx;
|
||||||
|
int recon_y_stride = pc->yv12_fb[dst_fb_idx].y_stride;
|
||||||
|
int recon_uv_stride = pc->yv12_fb[dst_fb_idx].uv_stride;
|
||||||
|
|
||||||
|
unsigned char *ref_buffer[MAX_REF_FRAMES][3];
|
||||||
|
unsigned char *dst_buffer[3];
|
||||||
|
int i;
|
||||||
|
int ref_fb_index[MAX_REF_FRAMES];
|
||||||
|
int ref_fb_corrupted[MAX_REF_FRAMES];
|
||||||
|
|
||||||
|
ref_fb_corrupted[INTRA_FRAME] = 0;
|
||||||
|
|
||||||
|
ref_fb_index[LAST_FRAME] = pc->lst_fb_idx;
|
||||||
|
ref_fb_index[GOLDEN_FRAME] = pc->gld_fb_idx;
|
||||||
|
ref_fb_index[ALTREF_FRAME] = pc->alt_fb_idx;
|
||||||
|
|
||||||
|
for(i = 1; i < MAX_REF_FRAMES; i++)
|
||||||
|
{
|
||||||
|
ref_buffer[i][0] = pc->yv12_fb[ref_fb_index[i]].y_buffer;
|
||||||
|
ref_buffer[i][1] = pc->yv12_fb[ref_fb_index[i]].u_buffer;
|
||||||
|
ref_buffer[i][2] = pc->yv12_fb[ref_fb_index[i]].v_buffer;
|
||||||
|
|
||||||
|
ref_fb_corrupted[i] = pc->yv12_fb[ref_fb_index[i]].corrupted;
|
||||||
|
}
|
||||||
|
|
||||||
|
dst_buffer[0] = pc->yv12_fb[dst_fb_idx].y_buffer;
|
||||||
|
dst_buffer[1] = pc->yv12_fb[dst_fb_idx].u_buffer;
|
||||||
|
dst_buffer[2] = pc->yv12_fb[dst_fb_idx].v_buffer;
|
||||||
|
|
||||||
|
xd->up_available = 0;
|
||||||
|
|
||||||
|
/* Decode the individual macro block */
|
||||||
|
for (mb_row = 0; mb_row < pc->mb_rows; mb_row++)
|
||||||
|
{
|
||||||
|
if (num_part > 1)
|
||||||
|
{
|
||||||
|
xd->current_bc = & pbi->mbc[ibc];
|
||||||
|
ibc++;
|
||||||
|
|
||||||
|
if (ibc == num_part)
|
||||||
|
ibc = 0;
|
||||||
|
}
|
||||||
|
|
||||||
vpx_memset(&pc->left_context, 0, sizeof(pc->left_context));
|
|
||||||
recon_yoffset = mb_row * recon_y_stride * 16;
|
recon_yoffset = mb_row * recon_y_stride * 16;
|
||||||
recon_uvoffset = mb_row * recon_uv_stride * 8;
|
recon_uvoffset = mb_row * recon_uv_stride * 8;
|
||||||
/* reset above block coeffs */
|
|
||||||
|
|
||||||
|
/* reset contexts */
|
||||||
xd->above_context = pc->above_context;
|
xd->above_context = pc->above_context;
|
||||||
xd->up_available = (mb_row != 0);
|
vpx_memset(xd->left_context, 0, sizeof(ENTROPY_CONTEXT_PLANES));
|
||||||
|
|
||||||
|
xd->left_available = 0;
|
||||||
|
|
||||||
xd->mb_to_top_edge = -((mb_row * 16)) << 3;
|
xd->mb_to_top_edge = -((mb_row * 16)) << 3;
|
||||||
xd->mb_to_bottom_edge = ((pc->mb_rows - 1 - mb_row) * 16) << 3;
|
xd->mb_to_bottom_edge = ((pc->mb_rows - 1 - mb_row) * 16) << 3;
|
||||||
@@ -374,31 +418,21 @@ decode_mb_row(VP8D_COMP *pbi, VP8_COMMON *pc, int mb_row, MACROBLOCKD *xd)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
xd->dst.y_buffer = pc->yv12_fb[dst_fb_idx].y_buffer + recon_yoffset;
|
xd->dst.y_buffer = dst_buffer[0] + recon_yoffset;
|
||||||
xd->dst.u_buffer = pc->yv12_fb[dst_fb_idx].u_buffer + recon_uvoffset;
|
xd->dst.u_buffer = dst_buffer[1] + recon_uvoffset;
|
||||||
xd->dst.v_buffer = pc->yv12_fb[dst_fb_idx].v_buffer + recon_uvoffset;
|
xd->dst.v_buffer = dst_buffer[2] + recon_uvoffset;
|
||||||
|
|
||||||
xd->left_available = (mb_col != 0);
|
xd->pre.y_buffer = ref_buffer[xd->mode_info_context->mbmi.ref_frame][0] + recon_yoffset;
|
||||||
|
xd->pre.u_buffer = ref_buffer[xd->mode_info_context->mbmi.ref_frame][1] + recon_uvoffset;
|
||||||
|
xd->pre.v_buffer = ref_buffer[xd->mode_info_context->mbmi.ref_frame][2] + recon_uvoffset;
|
||||||
|
|
||||||
/* Select the appropriate reference frame for this MB */
|
|
||||||
if (xd->mode_info_context->mbmi.ref_frame == LAST_FRAME)
|
|
||||||
ref_fb_idx = pc->lst_fb_idx;
|
|
||||||
else if (xd->mode_info_context->mbmi.ref_frame == GOLDEN_FRAME)
|
|
||||||
ref_fb_idx = pc->gld_fb_idx;
|
|
||||||
else
|
|
||||||
ref_fb_idx = pc->alt_fb_idx;
|
|
||||||
|
|
||||||
xd->pre.y_buffer = pc->yv12_fb[ref_fb_idx].y_buffer + recon_yoffset;
|
|
||||||
xd->pre.u_buffer = pc->yv12_fb[ref_fb_idx].u_buffer + recon_uvoffset;
|
|
||||||
xd->pre.v_buffer = pc->yv12_fb[ref_fb_idx].v_buffer + recon_uvoffset;
|
|
||||||
|
|
||||||
if (xd->mode_info_context->mbmi.ref_frame != INTRA_FRAME)
|
|
||||||
{
|
|
||||||
/* propagate errors from reference frames */
|
/* propagate errors from reference frames */
|
||||||
xd->corrupted |= pc->yv12_fb[ref_fb_idx].corrupted;
|
xd->corrupted |= ref_fb_corrupted[xd->mode_info_context->mbmi.ref_frame];
|
||||||
}
|
|
||||||
|
|
||||||
decode_macroblock(pbi, xd, mb_row * pc->mb_cols + mb_col);
|
decode_macroblock(pbi, xd, mb_idx);
|
||||||
|
|
||||||
|
mb_idx++;
|
||||||
|
xd->left_available = 1;
|
||||||
|
|
||||||
/* check if the boolean decoder has suffered an error */
|
/* check if the boolean decoder has suffered an error */
|
||||||
xd->corrupted |= vp8dx_bool_error(xd->current_bc);
|
xd->corrupted |= vp8dx_bool_error(xd->current_bc);
|
||||||
@@ -419,8 +453,10 @@ decode_mb_row(VP8D_COMP *pbi, VP8_COMMON *pc, int mb_row, MACROBLOCKD *xd)
|
|||||||
);
|
);
|
||||||
|
|
||||||
++xd->mode_info_context; /* skip prediction column */
|
++xd->mode_info_context; /* skip prediction column */
|
||||||
}
|
xd->up_available = 1;
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static unsigned int read_partition_size(const unsigned char *cx_size)
|
static unsigned int read_partition_size(const unsigned char *cx_size)
|
||||||
{
|
{
|
||||||
@@ -672,7 +708,6 @@ int vp8_decode_frame(VP8D_COMP *pbi)
|
|||||||
const unsigned char *data_end = data + pbi->fragment_sizes[0];
|
const unsigned char *data_end = data + pbi->fragment_sizes[0];
|
||||||
ptrdiff_t first_partition_length_in_bytes;
|
ptrdiff_t first_partition_length_in_bytes;
|
||||||
|
|
||||||
int mb_row;
|
|
||||||
int i, j, k, l;
|
int i, j, k, l;
|
||||||
const int *const mb_feature_data_bits = vp8_mb_feature_data_bits;
|
const int *const mb_feature_data_bits = vp8_mb_feature_data_bits;
|
||||||
int corrupt_tokens = 0;
|
int corrupt_tokens = 0;
|
||||||
@@ -1068,12 +1103,12 @@ int vp8_decode_frame(VP8D_COMP *pbi)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
vpx_memset(pc->above_context, 0, sizeof(ENTROPY_CONTEXT_PLANES) * pc->mb_cols);
|
vpx_memset(pc->above_context, 0, sizeof(ENTROPY_CONTEXT_PLANES) * pc->mb_cols);
|
||||||
|
pbi->frame_corrupt_residual = 0;
|
||||||
|
|
||||||
#if CONFIG_MULTITHREAD
|
#if CONFIG_MULTITHREAD
|
||||||
if (pbi->b_multithreaded_rd && pc->multi_token_partition != ONE_PARTITION)
|
if (pbi->b_multithreaded_rd && pc->multi_token_partition != ONE_PARTITION)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
pbi->frame_corrupt_residual = 0;
|
|
||||||
vp8mt_decode_mb_rows(pbi, xd);
|
vp8mt_decode_mb_rows(pbi, xd);
|
||||||
vp8_yv12_extend_frame_borders_ptr(&pc->yv12_fb[pc->new_fb_idx]); /*cm->frame_to_show);*/
|
vp8_yv12_extend_frame_borders_ptr(&pc->yv12_fb[pc->new_fb_idx]); /*cm->frame_to_show);*/
|
||||||
for (i = 0; i < pbi->decoding_thread_count; ++i)
|
for (i = 0; i < pbi->decoding_thread_count; ++i)
|
||||||
@@ -1082,25 +1117,7 @@ int vp8_decode_frame(VP8D_COMP *pbi)
|
|||||||
else
|
else
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
int ibc = 0;
|
decode_mb_rows(pbi);
|
||||||
int num_part = 1 << pc->multi_token_partition;
|
|
||||||
pbi->frame_corrupt_residual = 0;
|
|
||||||
|
|
||||||
/* Decode the individual macro block */
|
|
||||||
for (mb_row = 0; mb_row < pc->mb_rows; mb_row++)
|
|
||||||
{
|
|
||||||
|
|
||||||
if (num_part > 1)
|
|
||||||
{
|
|
||||||
xd->current_bc = & pbi->mbc[ibc];
|
|
||||||
ibc++;
|
|
||||||
|
|
||||||
if (ibc == num_part)
|
|
||||||
ibc = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
decode_mb_row(pbi, pc, mb_row, xd);
|
|
||||||
}
|
|
||||||
corrupt_tokens |= xd->corrupted;
|
corrupt_tokens |= xd->corrupted;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -334,6 +334,33 @@ static void decode_mb_rows(VP8D_COMP *pbi, MACROBLOCKD *xd, int start_mb_row,
|
|||||||
int nsync = pbi->sync_range;
|
int nsync = pbi->sync_range;
|
||||||
int num_part = 1 << pbi->common.multi_token_partition;
|
int num_part = 1 << pbi->common.multi_token_partition;
|
||||||
|
|
||||||
|
int dst_fb_idx = pc->new_fb_idx;
|
||||||
|
unsigned char *ref_buffer[MAX_REF_FRAMES][3];
|
||||||
|
unsigned char *dst_buffer[3];
|
||||||
|
int i;
|
||||||
|
int ref_fb_index[MAX_REF_FRAMES];
|
||||||
|
int ref_fb_corrupted[MAX_REF_FRAMES];
|
||||||
|
|
||||||
|
ref_fb_corrupted[INTRA_FRAME] = 0;
|
||||||
|
|
||||||
|
ref_fb_index[LAST_FRAME] = pc->lst_fb_idx;
|
||||||
|
ref_fb_index[GOLDEN_FRAME] = pc->gld_fb_idx;
|
||||||
|
ref_fb_index[ALTREF_FRAME] = pc->alt_fb_idx;
|
||||||
|
|
||||||
|
for(i = 1; i < MAX_REF_FRAMES; i++)
|
||||||
|
{
|
||||||
|
ref_buffer[i][0] = pc->yv12_fb[ref_fb_index[i]].y_buffer;
|
||||||
|
ref_buffer[i][1] = pc->yv12_fb[ref_fb_index[i]].u_buffer;
|
||||||
|
ref_buffer[i][2] = pc->yv12_fb[ref_fb_index[i]].v_buffer;
|
||||||
|
|
||||||
|
ref_fb_corrupted[i] = pc->yv12_fb[ref_fb_index[i]].corrupted;
|
||||||
|
}
|
||||||
|
|
||||||
|
dst_buffer[0] = pc->yv12_fb[dst_fb_idx].y_buffer;
|
||||||
|
dst_buffer[1] = pc->yv12_fb[dst_fb_idx].u_buffer;
|
||||||
|
dst_buffer[2] = pc->yv12_fb[dst_fb_idx].v_buffer;
|
||||||
|
|
||||||
|
xd->up_available = (start_mb_row != 0);
|
||||||
|
|
||||||
for (mb_row = start_mb_row; mb_row < pc->mb_rows; mb_row += (pbi->decoding_thread_count + 1))
|
for (mb_row = start_mb_row; mb_row < pc->mb_rows; mb_row += (pbi->decoding_thread_count + 1))
|
||||||
{
|
{
|
||||||
@@ -355,11 +382,12 @@ static void decode_mb_rows(VP8D_COMP *pbi, MACROBLOCKD *xd, int start_mb_row,
|
|||||||
|
|
||||||
recon_yoffset = mb_row * recon_y_stride * 16;
|
recon_yoffset = mb_row * recon_y_stride * 16;
|
||||||
recon_uvoffset = mb_row * recon_uv_stride * 8;
|
recon_uvoffset = mb_row * recon_uv_stride * 8;
|
||||||
/* reset above block coeffs */
|
|
||||||
|
|
||||||
|
/* reset contexts */
|
||||||
xd->above_context = pc->above_context;
|
xd->above_context = pc->above_context;
|
||||||
vpx_memset(xd->left_context, 0, sizeof(ENTROPY_CONTEXT_PLANES));
|
vpx_memset(xd->left_context, 0, sizeof(ENTROPY_CONTEXT_PLANES));
|
||||||
xd->up_available = (mb_row != 0);
|
|
||||||
|
xd->left_available = 0;
|
||||||
|
|
||||||
xd->mb_to_top_edge = -((mb_row * 16)) << 3;
|
xd->mb_to_top_edge = -((mb_row * 16)) << 3;
|
||||||
xd->mb_to_bottom_edge = ((pc->mb_rows - 1 - mb_row) * 16) << 3;
|
xd->mb_to_bottom_edge = ((pc->mb_rows - 1 - mb_row) * 16) << 3;
|
||||||
@@ -413,33 +441,21 @@ static void decode_mb_rows(VP8D_COMP *pbi, MACROBLOCKD *xd, int start_mb_row,
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
xd->dst.y_buffer = pc->yv12_fb[dst_fb_idx].y_buffer + recon_yoffset;
|
xd->dst.y_buffer = dst_buffer[0] + recon_yoffset;
|
||||||
xd->dst.u_buffer = pc->yv12_fb[dst_fb_idx].u_buffer + recon_uvoffset;
|
xd->dst.u_buffer = dst_buffer[1] + recon_uvoffset;
|
||||||
xd->dst.v_buffer = pc->yv12_fb[dst_fb_idx].v_buffer + recon_uvoffset;
|
xd->dst.v_buffer = dst_buffer[2] + recon_uvoffset;
|
||||||
|
|
||||||
xd->left_available = (mb_col != 0);
|
xd->pre.y_buffer = ref_buffer[xd->mode_info_context->mbmi.ref_frame][0] + recon_yoffset;
|
||||||
|
xd->pre.u_buffer = ref_buffer[xd->mode_info_context->mbmi.ref_frame][1] + recon_uvoffset;
|
||||||
|
xd->pre.v_buffer = ref_buffer[xd->mode_info_context->mbmi.ref_frame][2] + recon_uvoffset;
|
||||||
|
|
||||||
/* Select the appropriate reference frame for this MB */
|
|
||||||
if (xd->mode_info_context->mbmi.ref_frame == LAST_FRAME)
|
|
||||||
ref_fb_idx = pc->lst_fb_idx;
|
|
||||||
else if (xd->mode_info_context->mbmi.ref_frame == GOLDEN_FRAME)
|
|
||||||
ref_fb_idx = pc->gld_fb_idx;
|
|
||||||
else
|
|
||||||
ref_fb_idx = pc->alt_fb_idx;
|
|
||||||
|
|
||||||
xd->pre.y_buffer = pc->yv12_fb[ref_fb_idx].y_buffer + recon_yoffset;
|
|
||||||
xd->pre.u_buffer = pc->yv12_fb[ref_fb_idx].u_buffer + recon_uvoffset;
|
|
||||||
xd->pre.v_buffer = pc->yv12_fb[ref_fb_idx].v_buffer + recon_uvoffset;
|
|
||||||
|
|
||||||
if (xd->mode_info_context->mbmi.ref_frame !=
|
|
||||||
INTRA_FRAME)
|
|
||||||
{
|
|
||||||
/* propagate errors from reference frames */
|
/* propagate errors from reference frames */
|
||||||
xd->corrupted |= pc->yv12_fb[ref_fb_idx].corrupted;
|
xd->corrupted |= ref_fb_corrupted[xd->mode_info_context->mbmi.ref_frame];
|
||||||
}
|
|
||||||
|
|
||||||
decode_macroblock(pbi, xd, mb_row, mb_col);
|
decode_macroblock(pbi, xd, mb_row, mb_col);
|
||||||
|
|
||||||
|
xd->left_available = 1;
|
||||||
|
|
||||||
/* check if the boolean decoder has suffered an error */
|
/* check if the boolean decoder has suffered an error */
|
||||||
xd->corrupted |= vp8dx_bool_error(xd->current_bc);
|
xd->corrupted |= vp8dx_bool_error(xd->current_bc);
|
||||||
|
|
||||||
@@ -563,6 +579,7 @@ static void decode_mb_rows(VP8D_COMP *pbi, MACROBLOCKD *xd, int start_mb_row,
|
|||||||
vp8_extend_mb_row(&pc->yv12_fb[dst_fb_idx], xd->dst.y_buffer + 16, xd->dst.u_buffer + 8, xd->dst.v_buffer + 8);
|
vp8_extend_mb_row(&pc->yv12_fb[dst_fb_idx], xd->dst.y_buffer + 16, xd->dst.u_buffer + 8, xd->dst.v_buffer + 8);
|
||||||
|
|
||||||
++xd->mode_info_context; /* skip prediction column */
|
++xd->mode_info_context; /* skip prediction column */
|
||||||
|
xd->up_available = 1;
|
||||||
|
|
||||||
/* since we have multithread */
|
/* since we have multithread */
|
||||||
xd->mode_info_context += xd->mode_info_stride * pbi->decoding_thread_count;
|
xd->mode_info_context += xd->mode_info_stride * pbi->decoding_thread_count;
|
||||||
|
|||||||
Reference in New Issue
Block a user