shithub: libvpx

Download patch

ref: e6485581febf7aa68836c6c570a1a6f8eca71c81
parent: 1efa79d32f290d2daa8cdb7d358232ba95e95a63
author: Ronald S. Bultje <[email protected]>
date: Thu May 30 08:49:38 EDT 2013

Remove splitmv.

We leave it in rdopt.c as a local define for now - this can be removed
later. In all other places, we remove it, thereby slightly decreasing
the size of some arrays in the bitstream.

Change-Id: Ic2a9beb97a4eda0b086f62c039d994b192f99ca5

--- a/vp9/common/vp9_blockd.h
+++ b/vp9/common/vp9_blockd.h
@@ -82,12 +82,11 @@
   NEARMV,
   ZEROMV,
   NEWMV,
-  SPLITMV,
   MB_MODE_COUNT
 } MB_PREDICTION_MODE;
 
 static INLINE int is_inter_mode(MB_PREDICTION_MODE mode) {
-  return mode >= NEARESTMV && mode <= SPLITMV;
+  return mode >= NEARESTMV && mode <= NEWMV;
 }
 
 #define INTRA_MODE_COUNT (TM_PRED + 1)
@@ -122,7 +121,7 @@
 #define VP9_UV_MODES (TM_PRED + 1)
 #define VP9_I32X32_MODES (TM_PRED + 1)
 
-#define VP9_MVREFS (1 + SPLITMV - NEARESTMV)
+#define VP9_MVREFS (1 + NEWMV - NEARESTMV)
 
 #define WHT_UPSCALE_FACTOR 2
 
@@ -690,7 +689,6 @@
     const MACROBLOCKD* const xd, BLOCK_SIZE_TYPE bsize, int plane,
     foreach_predicted_block_visitor visit, void *arg) {
   int i, x, y;
-  const MB_PREDICTION_MODE mode = xd->mode_info_context->mbmi.mode;
 
   // block sizes in number of 4x4 blocks log 2 ("*_b")
   // 4x4=0, 8x8=2, 16x16=4, 32x32=6, 64x64=8
@@ -701,7 +699,8 @@
   // size of the predictor to use.
   int pred_w, pred_h;
 
-  if (mode == SPLITMV) {
+  if (xd->mode_info_context->mbmi.sb_type < BLOCK_SIZE_SB8X8) {
+    assert(bsize == BLOCK_SIZE_SB8X8);
     pred_w = 0;
     pred_h = 0;
   } else {
--- a/vp9/common/vp9_entropymode.c
+++ b/vp9/common/vp9_entropymode.c
@@ -192,11 +192,6 @@
         ++mv_ref_ct[context][2][0];
       } else {
         ++mv_ref_ct[context][2][1];
-        if (m == NEWMV) {
-          ++mv_ref_ct[context][3][0];
-        } else {
-          ++mv_ref_ct[context][3][1];
-        }
       }
     }
   }
--- a/vp9/common/vp9_findnearmv.c
+++ b/vp9/common/vp9_findnearmv.c
@@ -24,11 +24,10 @@
   }
 }
 
-vp9_prob *vp9_mv_ref_probs(VP9_COMMON *pc, vp9_prob p[4], int context) {
+vp9_prob *vp9_mv_ref_probs(VP9_COMMON *pc, vp9_prob *p, int context) {
   p[0] = pc->fc.vp9_mode_contexts[context][0];
   p[1] = pc->fc.vp9_mode_contexts[context][1];
   p[2] = pc->fc.vp9_mode_contexts[context][2];
-  p[3] = pc->fc.vp9_mode_contexts[context][3];
   return p;
 }
 
--- a/vp9/common/vp9_loopfilter.c
+++ b/vp9/common/vp9_loopfilter.c
@@ -30,7 +30,6 @@
   lfi->mode_lf_lut[NEARESTMV] = 2;
   lfi->mode_lf_lut[NEARMV] = 2;
   lfi->mode_lf_lut[NEWMV] = 2;
-  lfi->mode_lf_lut[SPLITMV] = 3;
 }
 
 void vp9_loop_filter_update_sharpness(loop_filter_info_n *lfi,
--- a/vp9/common/vp9_mvref_common.c
+++ b/vp9/common/vp9_mvref_common.c
@@ -220,7 +220,8 @@
         add_candidate_mv(mv_ref_list, candidate_scores,
                          &refmv_count, c_refmv, 16);
       }
-      split_count += (candidate_mi->mbmi.mode == SPLITMV);
+      split_count += (candidate_mi->mbmi.sb_type < BLOCK_SIZE_SB8X8 &&
+                      candidate_mi->mbmi.ref_frame != INTRA_FRAME);
 
       // Count number of neihgbours coded intra and zeromv
       intra_count += (candidate_mi->mbmi.mode < NEARESTMV);
--- a/vp9/common/vp9_reconinter.c
+++ b/vp9/common/vp9_reconinter.c
@@ -392,8 +392,10 @@
 
   assert(x < bw);
   assert(y < bh);
-  assert(xd->mode_info_context->mbmi.mode == SPLITMV || 4 << pred_w == bw);
-  assert(xd->mode_info_context->mbmi.mode == SPLITMV || 4 << pred_h == bh);
+  assert(xd->mode_info_context->mbmi.sb_type < BLOCK_SIZE_SB8X8 ||
+         4 << pred_w == bw);
+  assert(xd->mode_info_context->mbmi.sb_type < BLOCK_SIZE_SB8X8 ||
+         4 << pred_h == bh);
 
   for (which_mv = 0; which_mv < 1 + use_second_ref; ++which_mv) {
     // source
@@ -412,7 +414,7 @@
     MV split_chroma_mv;
     int_mv clamped_mv;
 
-    if (xd->mode_info_context->mbmi.mode == SPLITMV) {
+    if (xd->mode_info_context->mbmi.sb_type < BLOCK_SIZE_SB8X8) {
       if (plane == 0) {
         mv = &xd->mode_info_context->bmi[block].as_mv[which_mv].as_mv;
       } else {
--- a/vp9/decoder/vp9_decodemv.c
+++ b/vp9/decoder/vp9_decodemv.c
@@ -569,15 +569,12 @@
       // If the segment level skip mode enabled
       if (vp9_segfeature_active(xd, mbmi->segment_id, SEG_LVL_SKIP)) {
         mbmi->mode = ZEROMV;
-      } else {
-        if (bsize >= BLOCK_SIZE_SB8X8)
-          mbmi->mode = read_sb_mv_ref(r, mv_ref_p);
-        else
-          mbmi->mode = SPLITMV;
+      } else if (bsize >= BLOCK_SIZE_SB8X8) {
+        mbmi->mode = read_sb_mv_ref(r, mv_ref_p);
         vp9_accum_mv_refs(cm, mbmi->mode, mbmi->mb_mode_context[ref_frame]);
       }
 
-      if (mbmi->mode != ZEROMV) {
+      if (bsize < BLOCK_SIZE_SB8X8 || mbmi->mode != ZEROMV) {
         vp9_find_best_ref_mvs(xd,
                               mbmi->ref_mvs[ref_frame],
                               &nearest, &nearby);
@@ -619,7 +616,7 @@
                          second_ref_frame, mbmi->ref_mvs[second_ref_frame],
                          cm->ref_frame_sign_bias);
 
-        if (mbmi->mode != ZEROMV) {
+        if (bsize < BLOCK_SIZE_SB8X8 || mbmi->mode != ZEROMV) {
           vp9_find_best_ref_mvs(xd,
                                 mbmi->ref_mvs[second_ref_frame],
                                 &nearest_second,
@@ -627,142 +624,142 @@
           best_mv_second.as_int = mbmi->ref_mvs[second_ref_frame][0].as_int;
         }
       }
-
     }
 
     mbmi->uv_mode = DC_PRED;
-    switch (mbmi->mode) {
-      case SPLITMV:
-        mbmi->need_to_clamp_mvs = 0;
-        for (idy = 0; idy < 2; idy += bh) {
-          for (idx = 0; idx < 2; idx += bw) {
-            int_mv blockmv, secondmv;
-            int blockmode;
-            int i;
-            j = idy * 2 + idx;
+    if (mbmi->sb_type < BLOCK_SIZE_SB8X8) {
+      mbmi->need_to_clamp_mvs = 0;
+      for (idy = 0; idy < 2; idy += bh) {
+        for (idx = 0; idx < 2; idx += bw) {
+          int_mv blockmv, secondmv;
+          int blockmode;
+          int i;
+          j = idy * 2 + idx;
 
-            blockmode = read_sb_mv_ref(r, mv_ref_p);
-            vp9_accum_mv_refs(cm, blockmode, mbmi->mb_mode_context[ref_frame]);
-            if (blockmode == NEARESTMV || blockmode == NEARMV) {
-              MV_REFERENCE_FRAME rf2 = mbmi->second_ref_frame;
-              vp9_append_sub8x8_mvs_for_idx(cm, xd, &nearest, &nearby, j, 0);
-              if (rf2 > 0) {
-                vp9_append_sub8x8_mvs_for_idx(cm, xd,  &nearest_second,
-                                              &nearby_second, j, 1);
-              }
+          blockmode = read_sb_mv_ref(r, mv_ref_p);
+          vp9_accum_mv_refs(cm, blockmode, mbmi->mb_mode_context[ref_frame]);
+          if (blockmode == NEARESTMV || blockmode == NEARMV) {
+            MV_REFERENCE_FRAME rf2 = mbmi->second_ref_frame;
+            vp9_append_sub8x8_mvs_for_idx(cm, xd, &nearest, &nearby, j, 0);
+            if (rf2 > 0) {
+              vp9_append_sub8x8_mvs_for_idx(cm, xd,  &nearest_second,
+                                            &nearby_second, j, 1);
             }
+          }
 
-            switch (blockmode) {
-              case NEWMV:
-                decode_mv(r, &blockmv.as_mv, &best_mv.as_mv, nmvc,
-                           &cm->fc.NMVcount, xd->allow_high_precision_mv);
+          switch (blockmode) {
+            case NEWMV:
+              decode_mv(r, &blockmv.as_mv, &best_mv.as_mv, nmvc,
+                         &cm->fc.NMVcount, xd->allow_high_precision_mv);
 
-                if (mbmi->second_ref_frame > 0)
-                  decode_mv(r, &secondmv.as_mv, &best_mv_second.as_mv, nmvc,
-                            &cm->fc.NMVcount, xd->allow_high_precision_mv);
+              if (mbmi->second_ref_frame > 0)
+                decode_mv(r, &secondmv.as_mv, &best_mv_second.as_mv, nmvc,
+                          &cm->fc.NMVcount, xd->allow_high_precision_mv);
 
-  #ifdef VPX_MODE_COUNT
-                vp9_mv_cont_count[mv_contz][3]++;
-  #endif
-                break;
-              case NEARESTMV:
-                blockmv.as_int = nearest.as_int;
-                if (mbmi->second_ref_frame > 0)
-                  secondmv.as_int = nearest_second.as_int;
-  #ifdef VPX_MODE_COUNT
-                vp9_mv_cont_count[mv_contz][0]++;
-  #endif
-                break;
-              case NEARMV:
-                blockmv.as_int = nearby.as_int;
-                if (mbmi->second_ref_frame > 0)
-                  secondmv.as_int = nearby_second.as_int;
-  #ifdef VPX_MODE_COUNT
-                vp9_mv_cont_count[mv_contz][1]++;
-  #endif
-                break;
-              case ZEROMV:
-                blockmv.as_int = 0;
-                if (mbmi->second_ref_frame > 0)
-                  secondmv.as_int = 0;
-  #ifdef VPX_MODE_COUNT
-                vp9_mv_cont_count[mv_contz][2]++;
-  #endif
-                break;
-              default:
-                break;
-            }
-            mi->bmi[j].as_mv[0].as_int = blockmv.as_int;
-            if (mbmi->second_ref_frame > 0)
-              mi->bmi[j].as_mv[1].as_int = secondmv.as_int;
-
-            for (i = 1; i < bh; ++i)
-              vpx_memcpy(&mi->bmi[j + i * 2], &mi->bmi[j], sizeof(mi->bmi[j]));
-            for (i = 1; i < bw; ++i)
-              vpx_memcpy(&mi->bmi[j + i], &mi->bmi[j], sizeof(mi->bmi[j]));
+#ifdef VPX_MODE_COUNT
+              vp9_mv_cont_count[mv_contz][3]++;
+#endif
+              break;
+            case NEARESTMV:
+              blockmv.as_int = nearest.as_int;
+              if (mbmi->second_ref_frame > 0)
+                secondmv.as_int = nearest_second.as_int;
+#ifdef VPX_MODE_COUNT
+              vp9_mv_cont_count[mv_contz][0]++;
+#endif
+              break;
+            case NEARMV:
+              blockmv.as_int = nearby.as_int;
+              if (mbmi->second_ref_frame > 0)
+                secondmv.as_int = nearby_second.as_int;
+#ifdef VPX_MODE_COUNT
+              vp9_mv_cont_count[mv_contz][1]++;
+#endif
+              break;
+            case ZEROMV:
+              blockmv.as_int = 0;
+              if (mbmi->second_ref_frame > 0)
+                secondmv.as_int = 0;
+#ifdef VPX_MODE_COUNT
+              vp9_mv_cont_count[mv_contz][2]++;
+#endif
+              break;
+            default:
+              break;
           }
+          mi->bmi[j].as_mv[0].as_int = blockmv.as_int;
+          if (mbmi->second_ref_frame > 0)
+            mi->bmi[j].as_mv[1].as_int = secondmv.as_int;
+
+          for (i = 1; i < bh; ++i)
+            vpx_memcpy(&mi->bmi[j + i * 2], &mi->bmi[j], sizeof(mi->bmi[j]));
+          for (i = 1; i < bw; ++i)
+            vpx_memcpy(&mi->bmi[j + i], &mi->bmi[j], sizeof(mi->bmi[j]));
+          mi->mbmi.mode = blockmode;
         }
+      }
 
-        mv0->as_int = mi->bmi[3].as_mv[0].as_int;
-        mv1->as_int = mi->bmi[3].as_mv[1].as_int;
-        break;  /* done with SPLITMV */
+      mv0->as_int = mi->bmi[3].as_mv[0].as_int;
+      mv1->as_int = mi->bmi[3].as_mv[1].as_int;
+    } else {
+      switch (mbmi->mode) {
+        case NEARMV:
+          // Clip "next_nearest" so that it does not extend to far out of image
+          assign_and_clamp_mv(mv0, &nearby, mb_to_left_edge,
+                                            mb_to_right_edge,
+                                            mb_to_top_edge,
+                                            mb_to_bottom_edge);
+          if (mbmi->second_ref_frame > 0)
+            assign_and_clamp_mv(mv1, &nearby_second, mb_to_left_edge,
+                                                     mb_to_right_edge,
+                                                     mb_to_top_edge,
+                                                     mb_to_bottom_edge);
+          break;
 
-      case NEARMV:
-        // Clip "next_nearest" so that it does not extend to far out of image
-        assign_and_clamp_mv(mv0, &nearby, mb_to_left_edge,
-                                          mb_to_right_edge,
-                                          mb_to_top_edge,
-                                          mb_to_bottom_edge);
-        if (mbmi->second_ref_frame > 0)
-          assign_and_clamp_mv(mv1, &nearby_second, mb_to_left_edge,
-                                                   mb_to_right_edge,
-                                                   mb_to_top_edge,
-                                                   mb_to_bottom_edge);
-        break;
+        case NEARESTMV:
+          // Clip "next_nearest" so that it does not extend to far out of image
+          assign_and_clamp_mv(mv0, &nearest, mb_to_left_edge,
+                                             mb_to_right_edge,
+                                             mb_to_top_edge,
+                                             mb_to_bottom_edge);
+          if (mbmi->second_ref_frame > 0)
+            assign_and_clamp_mv(mv1, &nearest_second, mb_to_left_edge,
+                                                      mb_to_right_edge,
+                                                      mb_to_top_edge,
+                                                      mb_to_bottom_edge);
+          break;
 
-      case NEARESTMV:
-        // Clip "next_nearest" so that it does not extend to far out of image
-        assign_and_clamp_mv(mv0, &nearest, mb_to_left_edge,
-                                           mb_to_right_edge,
-                                           mb_to_top_edge,
-                                           mb_to_bottom_edge);
-        if (mbmi->second_ref_frame > 0)
-          assign_and_clamp_mv(mv1, &nearest_second, mb_to_left_edge,
+        case ZEROMV:
+          mv0->as_int = 0;
+          if (mbmi->second_ref_frame > 0)
+            mv1->as_int = 0;
+          break;
+
+        case NEWMV:
+          decode_mv(r, &mv0->as_mv, &best_mv.as_mv, nmvc, &cm->fc.NMVcount,
+                    xd->allow_high_precision_mv);
+          mbmi->need_to_clamp_mvs = check_mv_bounds(mv0,
+                                                    mb_to_left_edge,
                                                     mb_to_right_edge,
                                                     mb_to_top_edge,
                                                     mb_to_bottom_edge);
-        break;
 
-      case ZEROMV:
-        mv0->as_int = 0;
-        if (mbmi->second_ref_frame > 0)
-          mv1->as_int = 0;
-        break;
-
-      case NEWMV:
-        decode_mv(r, &mv0->as_mv, &best_mv.as_mv, nmvc, &cm->fc.NMVcount,
-                  xd->allow_high_precision_mv);
-        mbmi->need_to_clamp_mvs = check_mv_bounds(mv0,
-                                                  mb_to_left_edge,
-                                                  mb_to_right_edge,
-                                                  mb_to_top_edge,
-                                                  mb_to_bottom_edge);
-
-        if (mbmi->second_ref_frame > 0) {
-          decode_mv(r, &mv1->as_mv, &best_mv_second.as_mv, nmvc,
-                    &cm->fc.NMVcount, xd->allow_high_precision_mv);
-          mbmi->need_to_clamp_secondmv = check_mv_bounds(mv1,
-                                                         mb_to_left_edge,
-                                                         mb_to_right_edge,
-                                                         mb_to_top_edge,
-                                                         mb_to_bottom_edge);
-        }
-        break;
-      default:
-;
+          if (mbmi->second_ref_frame > 0) {
+            decode_mv(r, &mv1->as_mv, &best_mv_second.as_mv, nmvc,
+                      &cm->fc.NMVcount, xd->allow_high_precision_mv);
+            mbmi->need_to_clamp_secondmv = check_mv_bounds(mv1,
+                                                             mb_to_left_edge,
+                                                             mb_to_right_edge,
+                                                             mb_to_top_edge,
+                                                             mb_to_bottom_edge);
+          }
+          break;
+        default:
 #if CONFIG_DEBUG
-        assert(0);
+          assert(0);
 #endif
+          break;
+      }
     }
   } else {
     // required for left and above block mv
--- a/vp9/encoder/vp9_bitstream.c
+++ b/vp9/encoder/vp9_bitstream.c
@@ -512,7 +512,7 @@
 static void write_sb_mv_ref(vp9_writer *bc, MB_PREDICTION_MODE m,
                             const vp9_prob *p) {
 #if CONFIG_DEBUG
-  assert(NEARESTMV <= m  &&  m < SPLITMV);
+  assert(NEARESTMV <= m && m <= NEWMV);
 #endif
   write_token(bc, vp9_sb_mv_ref_tree, p,
               vp9_sb_mv_ref_encoding_array - NEARESTMV + m);
@@ -717,21 +717,20 @@
 
     // If segment skip is not enabled code the mode.
     if (!vp9_segfeature_active(xd, segment_id, SEG_LVL_SKIP)) {
-      if (mi->sb_type >= BLOCK_SIZE_SB8X8)
+      if (mi->sb_type >= BLOCK_SIZE_SB8X8) {
         write_sb_mv_ref(bc, mode, mv_ref_p);
-      vp9_accum_mv_refs(&cpi->common, mode, mi->mb_mode_context[rf]);
+        vp9_accum_mv_refs(&cpi->common, mode, mi->mb_mode_context[rf]);
+      }
     }
 
-    if (is_inter_mode(mode)) {
-      if (cpi->common.mcomp_filter_type == SWITCHABLE) {
-        write_token(bc, vp9_switchable_interp_tree,
-                    vp9_get_pred_probs(&cpi->common, xd,
-                                       PRED_SWITCHABLE_INTERP),
-                    vp9_switchable_interp_encodings +
-                    vp9_switchable_interp_map[mi->interp_filter]);
-      } else {
-        assert(mi->interp_filter == cpi->common.mcomp_filter_type);
-      }
+    if (cpi->common.mcomp_filter_type == SWITCHABLE) {
+      write_token(bc, vp9_switchable_interp_tree,
+                  vp9_get_pred_probs(&cpi->common, xd,
+                                     PRED_SWITCHABLE_INTERP),
+                  vp9_switchable_interp_encodings +
+                  vp9_switchable_interp_map[mi->interp_filter]);
+    } else {
+      assert(mi->interp_filter == cpi->common.mcomp_filter_type);
     }
 
     // does the feature use compound prediction or not
@@ -741,57 +740,51 @@
                 vp9_get_pred_prob(pc, xd, PRED_COMP));
     }
 
-    switch (mode) { /* new, split require MVs */
-      case NEWMV:
+    if (xd->mode_info_context->mbmi.sb_type < BLOCK_SIZE_SB8X8) {
+      int j;
+      MB_PREDICTION_MODE blockmode;
+      int_mv blockmv;
+      int bwl = b_width_log2(mi->sb_type), bw = 1 << bwl;
+      int bhl = b_height_log2(mi->sb_type), bh = 1 << bhl;
+      int idx, idy;
+      for (idy = 0; idy < 2; idy += bh) {
+        for (idx = 0; idx < 2; idx += bw) {
+          j = idy * 2 + idx;
+          blockmode = cpi->mb.partition_info->bmi[j].mode;
+          blockmv = cpi->mb.partition_info->bmi[j].mv;
+          write_sb_mv_ref(bc, blockmode, mv_ref_p);
+          vp9_accum_mv_refs(&cpi->common, blockmode, mi->mb_mode_context[rf]);
+          if (blockmode == NEWMV) {
 #ifdef ENTROPY_STATS
-        active_section = 5;
+            active_section = 11;
 #endif
-        vp9_encode_mv(bc,
-                      &mi->mv[0].as_mv, &mi->best_mv.as_mv,
-                      nmvc, xd->allow_high_precision_mv);
+            vp9_encode_mv(bc, &blockmv.as_mv, &mi->best_mv.as_mv,
+                          nmvc, xd->allow_high_precision_mv);
 
-        if (mi->second_ref_frame > 0)
-          vp9_encode_mv(bc,
-                        &mi->mv[1].as_mv, &mi->best_second_mv.as_mv,
-                        nmvc, xd->allow_high_precision_mv);
-        break;
-      case SPLITMV: {
-        int j;
-        MB_PREDICTION_MODE blockmode;
-        int_mv blockmv;
-        int bwl = b_width_log2(mi->sb_type), bw = 1 << bwl;
-        int bhl = b_height_log2(mi->sb_type), bh = 1 << bhl;
-        int idx, idy;
-        for (idy = 0; idy < 2; idy += bh) {
-          for (idx = 0; idx < 2; idx += bw) {
-            j = idy * 2 + idx;
-            blockmode = cpi->mb.partition_info->bmi[j].mode;
-            blockmv = cpi->mb.partition_info->bmi[j].mv;
-            write_sb_mv_ref(bc, blockmode, mv_ref_p);
-            vp9_accum_mv_refs(&cpi->common, blockmode, mi->mb_mode_context[rf]);
-            if (blockmode == NEWMV) {
-#ifdef ENTROPY_STATS
-              active_section = 11;
-#endif
-              vp9_encode_mv(bc, &blockmv.as_mv, &mi->best_mv.as_mv,
+            if (mi->second_ref_frame > 0)
+              vp9_encode_mv(bc,
+                            &cpi->mb.partition_info->bmi[j].second_mv.as_mv,
+                            &mi->best_second_mv.as_mv,
                             nmvc, xd->allow_high_precision_mv);
-
-              if (mi->second_ref_frame > 0)
-                vp9_encode_mv(bc,
-                              &cpi->mb.partition_info->bmi[j].second_mv.as_mv,
-                              &mi->best_second_mv.as_mv,
-                              nmvc, xd->allow_high_precision_mv);
-            }
           }
         }
+      }
 
 #ifdef MODE_STATS
-        ++count_mb_seg[mi->partitioning];
+      ++count_mb_seg[mi->partitioning];
 #endif
-        break;
-      }
-      default:
-        break;
+    } else if (mode == NEWMV) {
+#ifdef ENTROPY_STATS
+      active_section = 5;
+#endif
+      vp9_encode_mv(bc,
+                    &mi->mv[0].as_mv, &mi->best_mv.as_mv,
+                    nmvc, xd->allow_high_precision_mv);
+
+      if (mi->second_ref_frame > 0)
+        vp9_encode_mv(bc,
+                      &mi->mv[1].as_mv, &mi->best_second_mv.as_mv,
+                      nmvc, xd->allow_high_precision_mv);
     }
   }
 }
--- a/vp9/encoder/vp9_encodeframe.c
+++ b/vp9/encoder/vp9_encodeframe.c
@@ -332,7 +332,9 @@
   MACROBLOCKD *const xd = &x->e_mbd;
   MODE_INFO *mi = &ctx->mic;
   MB_MODE_INFO *const mbmi = &xd->mode_info_context->mbmi;
-  int mb_mode = mi->mbmi.mode;
+#if CONFIG_DEBUG || CONFIG_INTERNAL_STATS
+  MB_PREDICTION_MODE mb_mode = mi->mbmi.mode;
+#endif
   int mb_mode_index = ctx->best_mode_index;
   const int mis = cpi->common.mode_info_stride;
   const int bh = 1 << mi_height_log2(bsize), bw = 1 << mi_width_log2(bsize);
@@ -362,7 +364,8 @@
     ctx->txfm_rd_diff[ALLOW_32X32] = ctx->txfm_rd_diff[ALLOW_16X16];
   }
 
-  if (mb_mode == SPLITMV) {
+  if (mbmi->ref_frame != INTRA_FRAME &&
+      mbmi->sb_type < BLOCK_SIZE_SB8X8) {
     vpx_memcpy(x->partition_info, &ctx->partition_info,
                sizeof(PARTITION_INFO));
 
@@ -448,7 +451,8 @@
     */
     // Note how often each mode chosen as best
     cpi->mode_chosen_counts[mb_mode_index]++;
-    if (mbmi->mode == SPLITMV || mbmi->mode == NEWMV) {
+    if (mbmi->ref_frame != INTRA_FRAME &&
+        (mbmi->sb_type < BLOCK_SIZE_SB8X8 || mbmi->mode == NEWMV)) {
       int_mv best_mv, best_second_mv;
       MV_REFERENCE_FRAME rf = mbmi->ref_frame;
       best_mv.as_int = ctx->best_ref_mv.as_int;
@@ -1617,7 +1621,7 @@
             cpi->zbin_mode_boost = GF_ZEROMV_ZBIN_BOOST;
           else
             cpi->zbin_mode_boost = LF_ZEROMV_ZBIN_BOOST;
-        } else if (mbmi->mode == SPLITMV) {
+        } else if (mbmi->sb_type < BLOCK_SIZE_SB8X8) {
           cpi->zbin_mode_boost = SPLIT_MV_ZBIN_BOOST;
         } else {
           cpi->zbin_mode_boost = MV_ZBIN_BOOST;
--- a/vp9/encoder/vp9_rdopt.c
+++ b/vp9/encoder/vp9_rdopt.c
@@ -50,6 +50,7 @@
                 vp9_pt_energy_class[MAX_ENTROPY_TOKENS]);
 
 #define I4X4_PRED 0x8000
+#define SPLITMV 0x10000
 
 const MODE_DEFINITION vp9_mode_order[MAX_MODES] = {
   {ZEROMV,    LAST_FRAME,   NONE},
@@ -988,7 +989,7 @@
     VP9_COMMON *pc = &cpi->common;
 
     vp9_prob p [VP9_MVREFS - 1];
-    assert(NEARESTMV <= m  &&  m <= SPLITMV);
+    assert(NEARESTMV <= m  &&  m <= NEWMV);
     vp9_mv_ref_probs(pc, p, mode_context);
     return cost_token(vp9_sb_mv_ref_tree, p,
                       vp9_sb_mv_ref_encoding_array - NEARESTMV + m);
@@ -1536,6 +1537,7 @@
   *returndistortion = bsi.d;
   *returnyrate = bsi.segment_yrate;
   *skippable = vp9_sby_is_skippable(&x->e_mbd, BLOCK_SIZE_SB8X8);
+  mbmi->mode = bsi.modes[3];
 
   return (int)(bsi.segment_rd);
 }
@@ -2896,7 +2898,6 @@
 
       compmode_cost =
           vp9_cost_bit(vp9_get_pred_prob(cm, xd, PRED_COMP), is_comp_pred);
-      mbmi->mode = this_mode;
     } else {
       YV12_BUFFER_CONFIG *scaled_ref_frame[2] = {NULL, NULL};
       int fb = get_ref_frame_idx(cpi, mbmi->ref_frame);
@@ -2991,7 +2992,7 @@
       best_mode = this_mode;
     }
 
-    if (this_mode != I4X4_PRED) {
+    if (this_mode != I4X4_PRED && this_mode != SPLITMV) {
       // Store the respective mode distortions for later use.
       if (mode_distortions[this_mode] == -1
           || distortion2 < mode_distortions[this_mode]) {
@@ -3107,8 +3108,7 @@
   // Flag all modes that have a distortion thats > 2x the best we found at
   // this level.
   for (mode_index = 0; mode_index < MB_MODE_COUNT; ++mode_index) {
-    if (mode_index == NEARESTMV || mode_index == NEARMV || mode_index == NEWMV
-        || mode_index == SPLITMV)
+    if (mode_index == NEARESTMV || mode_index == NEARMV || mode_index == NEWMV)
       continue;
 
     if (mode_distortions[mode_index] > 2 * *returndistortion) {
@@ -3191,7 +3191,8 @@
     }
   }
 
-  if (best_mbmode.mode == SPLITMV) {
+  if (best_mbmode.ref_frame != INTRA_FRAME &&
+      best_mbmode.sb_type < BLOCK_SIZE_SB8X8) {
     for (i = 0; i < 4; i++)
       xd->mode_info_context->bmi[i].as_mv[0].as_int =
           best_bmodes[i].as_mv[0].as_int;