Commit 06f730d8 authored by fbarchard@google.com's avatar fbarchard@google.com

Change do while loops to for loops to allow 0 or 1 wide

BUG=289
TESTED=drmemory on odd width
R=tpsiaki@google.com

Review URL: https://webrtc-codereview.appspot.com/4719004

git-svn-id: http://libyuv.googlecode.com/svn/trunk@882 16f28f9a-4ce2-e073-06de-1de4eb20be90
parent 0e82bd7e
Name: libyuv Name: libyuv
URL: http://code.google.com/p/libyuv/ URL: http://code.google.com/p/libyuv/
Version: 879 Version: 882
License: BSD License: BSD
License File: LICENSE License File: LICENSE
......
...@@ -11,6 +11,6 @@ ...@@ -11,6 +11,6 @@
#ifndef INCLUDE_LIBYUV_VERSION_H_ // NOLINT #ifndef INCLUDE_LIBYUV_VERSION_H_ // NOLINT
#define INCLUDE_LIBYUV_VERSION_H_ #define INCLUDE_LIBYUV_VERSION_H_
#define LIBYUV_VERSION 879 #define LIBYUV_VERSION 882
#endif // INCLUDE_LIBYUV_VERSION_H_ NOLINT #endif // INCLUDE_LIBYUV_VERSION_H_ NOLINT
...@@ -26,13 +26,12 @@ extern "C" { ...@@ -26,13 +26,12 @@ extern "C" {
// CPU agnostic row functions // CPU agnostic row functions
void ScaleRowDown2_C(const uint8* src_ptr, ptrdiff_t /* src_stride */, void ScaleRowDown2_C(const uint8* src_ptr, ptrdiff_t /* src_stride */,
uint8* dst, int dst_width) { uint8* dst, int dst_width) {
uint8* dend = dst + dst_width - 1; for (int x = 0; x < dst_width - 1; x += 2) {
do {
dst[0] = src_ptr[1]; dst[0] = src_ptr[1];
dst[1] = src_ptr[3]; dst[1] = src_ptr[3];
dst += 2; dst += 2;
src_ptr += 4; src_ptr += 4;
} while (dst < dend); }
if (dst_width & 1) { if (dst_width & 1) {
dst[0] = src_ptr[1]; dst[0] = src_ptr[1];
} }
...@@ -41,13 +40,12 @@ void ScaleRowDown2_C(const uint8* src_ptr, ptrdiff_t /* src_stride */, ...@@ -41,13 +40,12 @@ void ScaleRowDown2_C(const uint8* src_ptr, ptrdiff_t /* src_stride */,
void ScaleRowDown2Linear_C(const uint8* src_ptr, ptrdiff_t src_stride, void ScaleRowDown2Linear_C(const uint8* src_ptr, ptrdiff_t src_stride,
uint8* dst, int dst_width) { uint8* dst, int dst_width) {
const uint8* s = src_ptr; const uint8* s = src_ptr;
uint8* dend = dst + dst_width - 1; for (int x = 0; x < dst_width - 1; x += 2) {
do {
dst[0] = (s[0] + s[1] + 1) >> 1; dst[0] = (s[0] + s[1] + 1) >> 1;
dst[1] = (s[2] + s[3] + 1) >> 1; dst[1] = (s[2] + s[3] + 1) >> 1;
dst += 2; dst += 2;
s += 4; s += 4;
} while (dst < dend); }
if (dst_width & 1) { if (dst_width & 1) {
dst[0] = (s[0] + s[1] + 1) >> 1; dst[0] = (s[0] + s[1] + 1) >> 1;
} }
...@@ -57,14 +55,13 @@ void ScaleRowDown2Box_C(const uint8* src_ptr, ptrdiff_t src_stride, ...@@ -57,14 +55,13 @@ void ScaleRowDown2Box_C(const uint8* src_ptr, ptrdiff_t src_stride,
uint8* dst, int dst_width) { uint8* dst, int dst_width) {
const uint8* s = src_ptr; const uint8* s = src_ptr;
const uint8* t = src_ptr + src_stride; const uint8* t = src_ptr + src_stride;
uint8* dend = dst + dst_width - 1; for (int x = 0; x < dst_width - 1; x += 2) {
do {
dst[0] = (s[0] + s[1] + t[0] + t[1] + 2) >> 2; dst[0] = (s[0] + s[1] + t[0] + t[1] + 2) >> 2;
dst[1] = (s[2] + s[3] + t[2] + t[3] + 2) >> 2; dst[1] = (s[2] + s[3] + t[2] + t[3] + 2) >> 2;
dst += 2; dst += 2;
s += 4; s += 4;
t += 4; t += 4;
} while (dst < dend); }
if (dst_width & 1) { if (dst_width & 1) {
dst[0] = (s[0] + s[1] + t[0] + t[1] + 2) >> 2; dst[0] = (s[0] + s[1] + t[0] + t[1] + 2) >> 2;
} }
...@@ -72,13 +69,12 @@ void ScaleRowDown2Box_C(const uint8* src_ptr, ptrdiff_t src_stride, ...@@ -72,13 +69,12 @@ void ScaleRowDown2Box_C(const uint8* src_ptr, ptrdiff_t src_stride,
void ScaleRowDown4_C(const uint8* src_ptr, ptrdiff_t /* src_stride */, void ScaleRowDown4_C(const uint8* src_ptr, ptrdiff_t /* src_stride */,
uint8* dst, int dst_width) { uint8* dst, int dst_width) {
uint8* dend = dst + dst_width - 1; for (int x = 0; x < dst_width - 1; x += 2) {
do {
dst[0] = src_ptr[2]; dst[0] = src_ptr[2];
dst[1] = src_ptr[6]; dst[1] = src_ptr[6];
dst += 2; dst += 2;
src_ptr += 8; src_ptr += 8;
} while (dst < dend); }
if (dst_width & 1) { if (dst_width & 1) {
dst[0] = src_ptr[2]; dst[0] = src_ptr[2];
} }
...@@ -87,8 +83,7 @@ void ScaleRowDown4_C(const uint8* src_ptr, ptrdiff_t /* src_stride */, ...@@ -87,8 +83,7 @@ void ScaleRowDown4_C(const uint8* src_ptr, ptrdiff_t /* src_stride */,
void ScaleRowDown4Box_C(const uint8* src_ptr, ptrdiff_t src_stride, void ScaleRowDown4Box_C(const uint8* src_ptr, ptrdiff_t src_stride,
uint8* dst, int dst_width) { uint8* dst, int dst_width) {
intptr_t stride = src_stride; intptr_t stride = src_stride;
uint8* dend = dst + dst_width - 1; for (int x = 0; x < dst_width - 1; x += 2) {
do {
dst[0] = (src_ptr[0] + src_ptr[1] + src_ptr[2] + src_ptr[3] + dst[0] = (src_ptr[0] + src_ptr[1] + src_ptr[2] + src_ptr[3] +
src_ptr[stride + 0] + src_ptr[stride + 1] + src_ptr[stride + 0] + src_ptr[stride + 1] +
src_ptr[stride + 2] + src_ptr[stride + 3] + src_ptr[stride + 2] + src_ptr[stride + 3] +
...@@ -107,7 +102,7 @@ void ScaleRowDown4Box_C(const uint8* src_ptr, ptrdiff_t src_stride, ...@@ -107,7 +102,7 @@ void ScaleRowDown4Box_C(const uint8* src_ptr, ptrdiff_t src_stride,
8) >> 4; 8) >> 4;
dst += 2; dst += 2;
src_ptr += 8; src_ptr += 8;
} while (dst < dend); }
if (dst_width & 1) { if (dst_width & 1) {
dst[0] = (src_ptr[0] + src_ptr[1] + src_ptr[2] + src_ptr[3] + dst[0] = (src_ptr[0] + src_ptr[1] + src_ptr[2] + src_ptr[3] +
src_ptr[stride + 0] + src_ptr[stride + 1] + src_ptr[stride + 0] + src_ptr[stride + 1] +
...@@ -123,14 +118,13 @@ void ScaleRowDown4Box_C(const uint8* src_ptr, ptrdiff_t src_stride, ...@@ -123,14 +118,13 @@ void ScaleRowDown4Box_C(const uint8* src_ptr, ptrdiff_t src_stride,
void ScaleRowDown34_C(const uint8* src_ptr, ptrdiff_t /* src_stride */, void ScaleRowDown34_C(const uint8* src_ptr, ptrdiff_t /* src_stride */,
uint8* dst, int dst_width) { uint8* dst, int dst_width) {
assert((dst_width % 3 == 0) && (dst_width > 0)); assert((dst_width % 3 == 0) && (dst_width > 0));
uint8* dend = dst + dst_width; for (int x = 0; x < dst_width; x += 3) {
do {
dst[0] = src_ptr[0]; dst[0] = src_ptr[0];
dst[1] = src_ptr[1]; dst[1] = src_ptr[1];
dst[2] = src_ptr[3]; dst[2] = src_ptr[3];
dst += 3; dst += 3;
src_ptr += 4; src_ptr += 4;
} while (dst < dend); }
} }
// Filter rows 0 and 1 together, 3 : 1 // Filter rows 0 and 1 together, 3 : 1
...@@ -139,8 +133,7 @@ void ScaleRowDown34_0_Box_C(const uint8* src_ptr, ptrdiff_t src_stride, ...@@ -139,8 +133,7 @@ void ScaleRowDown34_0_Box_C(const uint8* src_ptr, ptrdiff_t src_stride,
assert((dst_width % 3 == 0) && (dst_width > 0)); assert((dst_width % 3 == 0) && (dst_width > 0));
const uint8* s = src_ptr; const uint8* s = src_ptr;
const uint8* t = src_ptr + src_stride; const uint8* t = src_ptr + src_stride;
uint8* dend = d + dst_width; for (int x = 0; x < dst_width; x += 3) {
do {
uint8 a0 = (s[0] * 3 + s[1] * 1 + 2) >> 2; uint8 a0 = (s[0] * 3 + s[1] * 1 + 2) >> 2;
uint8 a1 = (s[1] * 1 + s[2] * 1 + 1) >> 1; uint8 a1 = (s[1] * 1 + s[2] * 1 + 1) >> 1;
uint8 a2 = (s[2] * 1 + s[3] * 3 + 2) >> 2; uint8 a2 = (s[2] * 1 + s[3] * 3 + 2) >> 2;
...@@ -153,7 +146,7 @@ void ScaleRowDown34_0_Box_C(const uint8* src_ptr, ptrdiff_t src_stride, ...@@ -153,7 +146,7 @@ void ScaleRowDown34_0_Box_C(const uint8* src_ptr, ptrdiff_t src_stride,
d += 3; d += 3;
s += 4; s += 4;
t += 4; t += 4;
} while (d < dend); }
} }
// Filter rows 1 and 2 together, 1 : 1 // Filter rows 1 and 2 together, 1 : 1
...@@ -162,8 +155,7 @@ void ScaleRowDown34_1_Box_C(const uint8* src_ptr, ptrdiff_t src_stride, ...@@ -162,8 +155,7 @@ void ScaleRowDown34_1_Box_C(const uint8* src_ptr, ptrdiff_t src_stride,
assert((dst_width % 3 == 0) && (dst_width > 0)); assert((dst_width % 3 == 0) && (dst_width > 0));
const uint8* s = src_ptr; const uint8* s = src_ptr;
const uint8* t = src_ptr + src_stride; const uint8* t = src_ptr + src_stride;
uint8* dend = d + dst_width; for (int x = 0; x < dst_width; x += 3) {
do {
uint8 a0 = (s[0] * 3 + s[1] * 1 + 2) >> 2; uint8 a0 = (s[0] * 3 + s[1] * 1 + 2) >> 2;
uint8 a1 = (s[1] * 1 + s[2] * 1 + 1) >> 1; uint8 a1 = (s[1] * 1 + s[2] * 1 + 1) >> 1;
uint8 a2 = (s[2] * 1 + s[3] * 3 + 2) >> 2; uint8 a2 = (s[2] * 1 + s[3] * 3 + 2) >> 2;
...@@ -176,7 +168,7 @@ void ScaleRowDown34_1_Box_C(const uint8* src_ptr, ptrdiff_t src_stride, ...@@ -176,7 +168,7 @@ void ScaleRowDown34_1_Box_C(const uint8* src_ptr, ptrdiff_t src_stride,
d += 3; d += 3;
s += 4; s += 4;
t += 4; t += 4;
} while (d < dend); }
} }
// Scales a single row of pixels using point sampling. // Scales a single row of pixels using point sampling.
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment