Commit b0b22f88 authored by Frank Barchard's avatar Frank Barchard

Unroll C version of YUV blender for improved performance.

R=dhrosa@google.com, harryjin@google.com
BUG=libyuv:527

Review URL: https://codereview.chromium.org/1502343003 .
parent 48a919d8
...@@ -2017,16 +2017,23 @@ void ARGBBlendRow_C(const uint8* src_argb0, const uint8* src_argb1, ...@@ -2017,16 +2017,23 @@ void ARGBBlendRow_C(const uint8* src_argb0, const uint8* src_argb1,
} }
#undef BLEND #undef BLEND
#define UBLEND(f, b, a) (((a) * f) + ((255 - a) * b) + 255) >> 8
void BlendPlaneRow_C(const uint8* src0, const uint8* src1, void BlendPlaneRow_C(const uint8* src0, const uint8* src1,
const uint8* alpha, uint8* dst, int width) { const uint8* alpha, uint8* dst, int width) {
int x; int x;
for (x = 0; x < width; ++x) { for (x = 0; x < width - 1; x += 2) {
uint32 f = *src0++; dst[0] = UBLEND(src0[0], src1[0], alpha[0]);
uint32 b = *src1++; dst[1] = UBLEND(src0[1], src1[1], alpha[1]);
uint32 a = *alpha++; src0 += 2;
*dst++ = (((a) * f) + ((255 - a) * b) + 255) >> 8; src1 += 2;
alpha += 2;
dst += 2;
}
if (width & 1) {
dst[0] = UBLEND(src0[0], src1[0], alpha[0]);
} }
} }
#undef UBLEND
#define ATTENUATE(f, a) (a | (a << 8)) * (f | (f << 8)) >> 24 #define ATTENUATE(f, a) (a | (a << 8)) * (f | (f << 8)) >> 24
......
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