avfilter/vf_edgedetect: fix heap-buffer overflow
Fixes #8275
(cherry picked from commit de598f82f8
)
Signed-off-by: James Almer <jamrial@gmail.com>
This commit is contained in:
committed by
James Almer
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;
|
memcpy(dst, src, w); dst += dst_linesize; src += src_linesize;
|
||||||
for (j = 2; j < h - 2; j++) {
|
for (j = 2; j < h - 2; j++) {
|
||||||
dst[0] = src[0];
|
dst[0] = src[0];
|
||||||
dst[1] = src[1];
|
if (w > 1)
|
||||||
|
dst[1] = src[1];
|
||||||
for (i = 2; i < w - 2; i++) {
|
for (i = 2; i < w - 2; i++) {
|
||||||
/* Gaussian mask of size 5x5 with sigma = 1.4 */
|
/* Gaussian mask of size 5x5 with sigma = 1.4 */
|
||||||
dst[i] = ((src[-2*src_linesize + i-2] + src[2*src_linesize + i-2]) * 2
|
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+1] * 12
|
||||||
+ src[i+2] * 5) / 159;
|
+ src[i+2] * 5) / 159;
|
||||||
}
|
}
|
||||||
dst[i ] = src[i ];
|
if (w > 2)
|
||||||
dst[i + 1] = src[i + 1];
|
dst[i ] = src[i ];
|
||||||
|
if (w > 3)
|
||||||
|
dst[i + 1] = src[i + 1];
|
||||||
|
|
||||||
dst += dst_linesize;
|
dst += dst_linesize;
|
||||||
src += src_linesize;
|
src += src_linesize;
|
||||||
|
Reference in New Issue
Block a user