diff options
author | Ronald S. Bultje <rsbultje@gmail.com> | 2011-12-18 08:27:43 -0800 |
---|---|---|
committer | Ronald S. Bultje <rsbultje@gmail.com> | 2011-12-18 08:27:43 -0800 |
commit | d49352c7cc22fd8928a761a373c3508be17c9f19 (patch) | |
tree | b92b28efd23bdd7a85450536060ccb04931f2d32 /libavcodec/raw.c | |
parent | f40e7eb573a42cd90323a1273af9634bbaf7ef14 (diff) | |
download | ffmpeg-d49352c7cc22fd8928a761a373c3508be17c9f19.tar.gz |
swscale: fix overflows in vertical scaling at top/bottom edges.
This fixes integer multiplication overflows in RGB48 output
(vertical) scaling as detected by IOC. What happens is that for
certain types of filters (lanczos, spline, bicubic), the
intermediate sum of coefficients in the middle of a filter can
be larger than the fixed-point equivalent of 1.0, even if the
final sum is 1.0. This is fine and we support that.
However, at frame edges, initFilter() will merge the coefficients
for the off-screen pixels into the top or bottom pixel, such as
to emulate edge extension. This means that suddenly, a single
coefficient can be larger than the fixed-point equivalent of
1.0, which the vertical scaling routines do not support.
Therefore, remove the merging of coefficients for edges for
the vertical scaling filter, and instead add edge detection
to the scaler itself so that it copies the pointers (not data)
for the edges (i.e. it uses line[0] for line[-1] as well), so
that a single coefficient is never larger than the fixed-point
equivalent of 1.0.
Diffstat (limited to 'libavcodec/raw.c')
0 files changed, 0 insertions, 0 deletions