ref: 4dfa7589917d33f6683e2b039f9390a83be69c05
parent: e788146247d47e0e24ad92259f6f016ffcf7b55a
parent: b2f4257c391d5112eb14381d32161f7fb287a237
author: Yaowu Xu <yaowu@google.com>
date: Mon Oct 15 11:02:36 EDT 2012
Merge "Changed to use real pixels only for evaluating MVs" into experimental
--- a/vp8/common/findnearmv.c
+++ b/vp8/common/findnearmv.c
@@ -217,7 +217,7 @@
unsigned char *above_ref;
unsigned char *left_ref;
int sad;
- int sad_scores[MAX_MV_REFS];
+ int sad_scores[MAX_MV_REFS] = {0};
int_mv sorted_mvs[MAX_MV_REFS];
int zero_seen = FALSE;
@@ -259,12 +259,13 @@
((this_mv.as_mv.col + 3) >> 3):((this_mv.as_mv.col + 4) >> 3);
offset = ref_y_stride * row_offset + col_offset;
- sad = vp8_sad16x3_c(above_src, xd->dst.y_stride,
- above_ref + offset, ref_y_stride, INT_MAX);
-
- sad += vp8_sad3x16_c(left_src, xd->dst.y_stride,
- left_ref + offset, ref_y_stride, INT_MAX);
-
+ sad = 0;
+ if (xd->up_available)
+ sad += vp8_sad16x3_c(above_src, xd->dst.y_stride,
+ above_ref + offset, ref_y_stride, INT_MAX);
+ if (xd->left_available)
+ sad += vp8_sad3x16_c(left_src, xd->dst.y_stride,
+ left_ref + offset, ref_y_stride, INT_MAX);
// Add the entry to our list and then resort the list on score.
sad_scores[i] = sad;
sorted_mvs[i].as_int = this_mv.as_int;
--
⑨