mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-02-04 06:08:26 +02:00
avfilter/vf_edgedetect: fix heap-buffer overflow
Fixes #8275 (cherry picked from commit de598f82f8c3f8000e1948548e8088148e2b1f44) Signed-off-by: James Almer <jamrial@gmail.com>
This commit is contained in:
parent
da3d6068f3
commit
ac5a7d5a67
@ -154,7 +154,8 @@ static void gaussian_blur(AVFilterContext *ctx, int w, int h,
|
||||
memcpy(dst, src, w); dst += dst_linesize; src += src_linesize;
|
||||
for (j = 2; j < h - 2; j++) {
|
||||
dst[0] = src[0];
|
||||
dst[1] = src[1];
|
||||
if (w > 1)
|
||||
dst[1] = src[1];
|
||||
for (i = 2; i < w - 2; i++) {
|
||||
/* Gaussian mask of size 5x5 with sigma = 1.4 */
|
||||
dst[i] = ((src[-2*src_linesize + i-2] + src[2*src_linesize + i-2]) * 2
|
||||
@ -175,8 +176,10 @@ static void gaussian_blur(AVFilterContext *ctx, int w, int h,
|
||||
+ src[i+1] * 12
|
||||
+ src[i+2] * 5) / 159;
|
||||
}
|
||||
dst[i ] = src[i ];
|
||||
dst[i + 1] = src[i + 1];
|
||||
if (w > 2)
|
||||
dst[i ] = src[i ];
|
||||
if (w > 3)
|
||||
dst[i + 1] = src[i + 1];
|
||||
|
||||
dst += dst_linesize;
|
||||
src += src_linesize;
|
||||
|
Loading…
x
Reference in New Issue
Block a user