Commit 873d06c7 authored by Michael Niedermayer's avatar Michael Niedermayer

swscale/output: Fix alpha shift in yuv2gbrp_full_X_c()

Signed-off-by: 's avatarMichael Niedermayer <michael@niedermayer.cc>
parent a340cfef
...@@ -1979,10 +1979,8 @@ yuv2gbrp_full_X_c(SwsContext *c, const int16_t *lumFilter, ...@@ -1979,10 +1979,8 @@ yuv2gbrp_full_X_c(SwsContext *c, const int16_t *lumFilter,
for (j = 0; j < lumFilterSize; j++) for (j = 0; j < lumFilterSize; j++)
A += alpSrc[j][i] * lumFilter[j]; A += alpSrc[j][i] * lumFilter[j];
A >>= 19; if (A & 0xF8000000)
A = av_clip_uintp2(A, 27);
if (A & 0x100)
A = av_clip_uint8(A);
} }
Y -= c->yuv2rgb_y_offset; Y -= c->yuv2rgb_y_offset;
...@@ -2003,13 +2001,13 @@ yuv2gbrp_full_X_c(SwsContext *c, const int16_t *lumFilter, ...@@ -2003,13 +2001,13 @@ yuv2gbrp_full_X_c(SwsContext *c, const int16_t *lumFilter,
dest16[1][i] = B >> SH; dest16[1][i] = B >> SH;
dest16[2][i] = R >> SH; dest16[2][i] = R >> SH;
if (hasAlpha) if (hasAlpha)
dest16[3][i] = A; dest16[3][i] = A >> (SH - 3);
} else { } else {
dest[0][i] = G >> 22; dest[0][i] = G >> 22;
dest[1][i] = B >> 22; dest[1][i] = B >> 22;
dest[2][i] = R >> 22; dest[2][i] = R >> 22;
if (hasAlpha) if (hasAlpha)
dest[3][i] = A; dest[3][i] = A >> 19;
} }
} }
if (SH != 22 && (!isBE(c->dstFormat)) != (!HAVE_BIGENDIAN)) { if (SH != 22 && (!isBE(c->dstFormat)) != (!HAVE_BIGENDIAN)) {
......
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