shithub: libvpx

Download patch

ref: bbb490f6a34d42991bcd627a816bda0fc729d0b8
parent: 4505e8accbe2b88a029f20fc0cc0cddc966e42cd
parent: af13fbb70f5c0424001115c56cd2ad2e6d85d18f
author: Jim Bankoski <jimbankoski@google.com>
date: Mon Aug 26 11:27:14 EDT 2013

Merge "Fix Chroma plane md5 check"

--- a/test/md5_helper.h
+++ b/test/md5_helper.h
@@ -25,9 +25,15 @@
 
   void Add(const vpx_image_t *img) {
     for (int plane = 0; plane < 3; ++plane) {
-      uint8_t *buf = img->planes[plane];
-      const int h = plane ? (img->d_h + 1) >> 1 : img->d_h;
-      const int w = plane ? (img->d_w + 1) >> 1 : img->d_w;
+      const uint8_t *buf = img->planes[plane];
+      // Calculate the width and height to do the md5 check. For the chroma
+      // plane, we never want to round down and thus skip a pixel so if
+      // we are shifting by 1 (chroma_shift) we add 1 before doing the shift.
+      // This works only for chroma_shift of 0 and 1.
+      const int h = plane ? (img->d_h + img->y_chroma_shift) >>
+                    img->y_chroma_shift : img->d_h;
+      const int w = plane ? (img->d_w + img->x_chroma_shift) >>
+                    img->x_chroma_shift : img->d_w;
 
       for (int y = 0; y < h; ++y) {
         MD5Update(&md5_, buf, w);