Merge "Removed read_mv_ref"

This commit is contained in:
Scott LaVarnway 2011-10-25 08:01:32 -07:00 committed by Gerrit Code Review
commit 3579baa115

View File

@ -138,14 +138,6 @@ static void read_mvcontexts(vp8_reader *bc, MV_CONTEXT *mvc)
while (++i < 2); while (++i < 2);
} }
static MB_PREDICTION_MODE read_mv_ref(vp8_reader *bc, const vp8_prob *p)
{
const int i = vp8_treed_read(bc, vp8_mv_ref_tree, p);
return (MB_PREDICTION_MODE)i;
}
static B_PREDICTION_MODE sub_mv_ref(vp8_reader *bc, const vp8_prob *p) static B_PREDICTION_MODE sub_mv_ref(vp8_reader *bc, const vp8_prob *p)
{ {
const int i = vp8_treed_read(bc, vp8_sub_mv_ref_tree, p); const int i = vp8_treed_read(bc, vp8_sub_mv_ref_tree, p);
@ -320,6 +312,7 @@ static void read_mb_modes_mv(VP8D_COMP *pbi, MODE_INFO *mi, MB_MODE_INFO *mbmi,
int rct[4]; int rct[4];
vp8_prob mv_ref_p [VP8_MVREFS-1]; vp8_prob mv_ref_p [VP8_MVREFS-1];
int_mv nearest, nearby, best_mv; int_mv nearest, nearby, best_mv;
int propogate_mv_for_ec = 0;
if (vp8_read(bc, pbi->prob_last)) if (vp8_read(bc, pbi->prob_last))
{ {
@ -332,48 +325,64 @@ static void read_mb_modes_mv(VP8D_COMP *pbi, MODE_INFO *mi, MB_MODE_INFO *mbmi,
vp8_mv_ref_probs(mv_ref_p, rct); vp8_mv_ref_probs(mv_ref_p, rct);
mbmi->uv_mode = DC_PRED; if( vp8_read(bc, mv_ref_p[0]) )
switch (mbmi->mode = read_mv_ref(bc, mv_ref_p)) {
if( vp8_read(bc, mv_ref_p[1]) )
{
if( vp8_read(bc, mv_ref_p[2]) )
{
if( vp8_read(bc, mv_ref_p[3]) )
{ {
case SPLITMV:
decode_split_mv(bc, mi, mbmi, mis, best_mv, mvc, decode_split_mv(bc, mi, mbmi, mis, best_mv, mvc,
mb_to_left_edge, mb_to_right_edge, mb_to_left_edge, mb_to_right_edge,
mb_to_top_edge, mb_to_bottom_edge); mb_to_top_edge, mb_to_bottom_edge);
mv->as_int = mi->bmi[15].mv.as_int; mv->as_int = mi->bmi[15].mv.as_int;
mbmi->mode = SPLITMV;
break; /* done with SPLITMV */ }
else
case NEARMV: {
mv->as_int = nearby.as_int;
goto propagate_mv;
case NEARESTMV:
mv->as_int = nearest.as_int;
goto propagate_mv;
case ZEROMV:
mv->as_int = 0;
goto propagate_mv;
case NEWMV:
read_mv(bc, &mv->as_mv, (const MV_CONTEXT *) mvc); read_mv(bc, &mv->as_mv, (const MV_CONTEXT *) mvc);
mv->as_mv.row += best_mv.as_mv.row; mv->as_mv.row += best_mv.as_mv.row;
mv->as_mv.col += best_mv.as_mv.col; mv->as_mv.col += best_mv.as_mv.col;
/* Don't need to check this on NEARMV and NEARESTMV modes /* Don't need to check this on NEARMV and NEARESTMV
* since those modes clamp the MV. The NEWMV mode does not, * modes since those modes clamp the MV. The NEWMV mode
* so signal to the prediction stage whether special * does not, so signal to the prediction stage whether
* handling may be required. * special handling may be required.
*/ */
mbmi->need_to_clamp_mvs = vp8_check_mv_bounds(mv, mbmi->need_to_clamp_mvs =
mb_to_left_edge, vp8_check_mv_bounds(mv, mb_to_left_edge,
mb_to_right_edge, mb_to_right_edge,
mb_to_top_edge, mb_to_top_edge,
mb_to_bottom_edge); mb_to_bottom_edge);
mbmi->mode = NEWMV;
propogate_mv_for_ec = 1;
}
}
else
{
mbmi->mode = NEARMV;
mbmi->mv.as_int = nearby.as_int;
propogate_mv_for_ec = 1;
}
}
else
{
mbmi->mode = NEARESTMV;
mbmi->mv.as_int = nearest.as_int;
propogate_mv_for_ec = 1;
}
}
else {
mbmi->mode = ZEROMV;
mbmi->mv.as_int = 0;
propogate_mv_for_ec = 1;
}
mbmi->uv_mode = DC_PRED;
propagate_mv: /* same MV throughout */
#if CONFIG_ERROR_CONCEALMENT #if CONFIG_ERROR_CONCEALMENT
if(pbi->ec_enabled) if(pbi->ec_enabled && propogate_mv_for_ec)
{ {
mi->bmi[ 0].mv.as_int = mi->bmi[ 0].mv.as_int =
mi->bmi[ 1].mv.as_int = mi->bmi[ 1].mv.as_int =
@ -393,13 +402,6 @@ static void read_mb_modes_mv(VP8D_COMP *pbi, MODE_INFO *mi, MB_MODE_INFO *mbmi,
mi->bmi[15].mv.as_int = mv->as_int; mi->bmi[15].mv.as_int = mv->as_int;
} }
#endif #endif
break;
default:
#if CONFIG_DEBUG
assert(0);
#endif
break;
}
} }
else else
{ {