Fix SEG_LVL_SKIP in RD inter mode selection.

* Only use ZEROMV, disalowing the intra modes that were previously
  tested.
* Score rate and distortion as zero.

Change-Id: Ifcf99e272095725f11da1dcd26bd0f850683e680
This commit is contained in:
Alex Converse 2014-05-28 17:11:16 -07:00
parent e6fadb5ba8
commit b0a8057f67

View File

@ -2802,7 +2802,8 @@ static int64_t handle_inter_mode(VP9_COMP *cpi, MACROBLOCK *x,
*rate2 += vp9_get_switchable_rate(cpi); *rate2 += vp9_get_switchable_rate(cpi);
if (!is_comp_pred) { if (!is_comp_pred) {
if (!x->in_active_map) { if (!x->in_active_map ||
vp9_segfeature_active(&cm->seg, mbmi->segment_id, SEG_LVL_SKIP)) {
if (psse) if (psse)
*psse = 0; *psse = 0;
*distortion = 0; *distortion = 0;
@ -3119,9 +3120,7 @@ int64_t vp9_rd_pick_inter_mode_sb(VP9_COMP *cpi, MACROBLOCK *x,
// If the segment skip feature is enabled.... // If the segment skip feature is enabled....
// then do nothing if the current mode is not allowed.. // then do nothing if the current mode is not allowed..
if (vp9_segfeature_active(seg, segment_id, SEG_LVL_SKIP)) { if (vp9_segfeature_active(seg, segment_id, SEG_LVL_SKIP)) {
const int inter_non_zero_mode_mask = 0x1F7F7; mode_skip_mask = ~(1 << THR_ZEROMV);
mode_skip_mask |= inter_non_zero_mode_mask;
mode_skip_mask &= ~(1 << THR_ZEROMV);
inter_mode_mask = (1 << ZEROMV); inter_mode_mask = (1 << ZEROMV);
} }