Commit 7f77e904 authored by Ronald S. Bultje's avatar Ronald S. Bultje

swscale: clip before assigning tables in RGB output functions.

parent 48606252
...@@ -1005,15 +1005,17 @@ yuv2rgb_2_c_template(SwsContext *c, const int16_t *buf[2], ...@@ -1005,15 +1005,17 @@ yuv2rgb_2_c_template(SwsContext *c, const int16_t *buf[2],
int U = (ubuf0[i] * uvalpha1 + ubuf1[i] * uvalpha) >> 19; int U = (ubuf0[i] * uvalpha1 + ubuf1[i] * uvalpha) >> 19;
int V = (vbuf0[i] * uvalpha1 + vbuf1[i] * uvalpha) >> 19; int V = (vbuf0[i] * uvalpha1 + vbuf1[i] * uvalpha) >> 19;
int A1, A2; int A1, A2;
const void *r = c->table_rV[V], const void *r, *g, *b;
*g = (c->table_gU[U] + c->table_gV[V]),
*b = c->table_bU[U];
Y1 = av_clip_uint8(Y1); Y1 = av_clip_uint8(Y1);
Y2 = av_clip_uint8(Y2); Y2 = av_clip_uint8(Y2);
U = av_clip_uint8(U); U = av_clip_uint8(U);
V = av_clip_uint8(V); V = av_clip_uint8(V);
r = c->table_rV[V];
g = (c->table_gU[U] + c->table_gV[V]);
b = c->table_bU[U];
if (hasAlpha) { if (hasAlpha) {
A1 = (abuf0[i * 2 ] * yalpha1 + abuf1[i * 2 ] * yalpha) >> 19; A1 = (abuf0[i * 2 ] * yalpha1 + abuf1[i * 2 ] * yalpha) >> 19;
A2 = (abuf0[i * 2 + 1] * yalpha1 + abuf1[i * 2 + 1] * yalpha) >> 19; A2 = (abuf0[i * 2 + 1] * yalpha1 + abuf1[i * 2 + 1] * yalpha) >> 19;
...@@ -1043,15 +1045,17 @@ yuv2rgb_1_c_template(SwsContext *c, const int16_t *buf0, ...@@ -1043,15 +1045,17 @@ yuv2rgb_1_c_template(SwsContext *c, const int16_t *buf0,
int U = ubuf0[i] >> 7; int U = ubuf0[i] >> 7;
int V = vbuf0[i] >> 7; int V = vbuf0[i] >> 7;
int A1, A2; int A1, A2;
const void *r = c->table_rV[V], const void *r, *g, *b;
*g = (c->table_gU[U] + c->table_gV[V]),
*b = c->table_bU[U];
Y1 = av_clip_uint8(Y1); Y1 = av_clip_uint8(Y1);
Y2 = av_clip_uint8(Y2); Y2 = av_clip_uint8(Y2);
U = av_clip_uint8(U); U = av_clip_uint8(U);
V = av_clip_uint8(V); V = av_clip_uint8(V);
r = c->table_rV[V];
g = (c->table_gU[U] + c->table_gV[V]);
b = c->table_bU[U];
if (hasAlpha) { if (hasAlpha) {
A1 = abuf0[i * 2 ] >> 7; A1 = abuf0[i * 2 ] >> 7;
A2 = abuf0[i * 2 + 1] >> 7; A2 = abuf0[i * 2 + 1] >> 7;
...@@ -1070,15 +1074,17 @@ yuv2rgb_1_c_template(SwsContext *c, const int16_t *buf0, ...@@ -1070,15 +1074,17 @@ yuv2rgb_1_c_template(SwsContext *c, const int16_t *buf0,
int U = (ubuf0[i] + ubuf1[i]) >> 8; int U = (ubuf0[i] + ubuf1[i]) >> 8;
int V = (vbuf0[i] + vbuf1[i]) >> 8; int V = (vbuf0[i] + vbuf1[i]) >> 8;
int A1, A2; int A1, A2;
const void *r = c->table_rV[V], const void *r, *g, *b;
*g = (c->table_gU[U] + c->table_gV[V]),
*b = c->table_bU[U];
Y1 = av_clip_uint8(Y1); Y1 = av_clip_uint8(Y1);
Y2 = av_clip_uint8(Y2); Y2 = av_clip_uint8(Y2);
U = av_clip_uint8(U); U = av_clip_uint8(U);
V = av_clip_uint8(V); V = av_clip_uint8(V);
r = c->table_rV[V];
g = (c->table_gU[U] + c->table_gV[V]);
b = c->table_bU[U];
if (hasAlpha) { if (hasAlpha) {
A1 = abuf0[i * 2 ] >> 7; A1 = abuf0[i * 2 ] >> 7;
A2 = abuf0[i * 2 + 1] >> 7; A2 = abuf0[i * 2 + 1] >> 7;
......
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