avfilter/edge_template: Fix small inputs with gaussian_blur()

Fixes: out of array access
Fixes: Ticket10699
Fixes: poc5ffmpeg

Found-by: Zeng Yunxiang
Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
release/7.0
Michael Niedermayer 1 year ago
parent e6459abfad
commit c443658d26
No known key found for this signature in database
GPG Key ID: B18E8928B3948D64
  1. 27
      libavfilter/edge_template.c

@ -74,6 +74,7 @@ void fn(gaussian_blur)(int w, int h,
uint8_t *dst, int dst_linesize, uint8_t *dst, int dst_linesize,
const uint8_t *src, int src_linesize, int src_stride) const uint8_t *src, int src_linesize, int src_stride)
{ {
int j;
pixel *srcp = (pixel *)src; pixel *srcp = (pixel *)src;
pixel *dstp = (pixel *)dst; pixel *dstp = (pixel *)dst;
@ -81,12 +82,17 @@ void fn(gaussian_blur)(int w, int h,
src_linesize /= sizeof(pixel); src_linesize /= sizeof(pixel);
dst_linesize /= sizeof(pixel); dst_linesize /= sizeof(pixel);
memcpy(dstp, srcp, w*sizeof(pixel)); dstp += dst_linesize; srcp += src_linesize; for (j = 0; j < FFMIN(h, 2); j++) {
memcpy(dstp, srcp, w*sizeof(pixel)); dstp += dst_linesize; srcp += src_linesize; memcpy(dstp, srcp, w*sizeof(pixel));
for (int j = 2; j < h - 2; j++) { dstp += dst_linesize;
dstp[0] = srcp[(0)*src_stride]; srcp += src_linesize;
dstp[1] = srcp[(1)*src_stride]; }
for (int i = 2; i < w - 2; i++) {
for (; j < h - 2; j++) {
int i;
for (i = 0; i < FFMIN(w, 2); i++)
dstp[i] = srcp[i*src_stride];
for (; i < w - 2; i++) {
/* Gaussian mask of size 5x5 with sigma = 1.4 */ /* Gaussian mask of size 5x5 with sigma = 1.4 */
dstp[i] = ((srcp[-2*src_linesize + (i-2)*src_stride] + srcp[2*src_linesize + (i-2)*src_stride]) * 2 dstp[i] = ((srcp[-2*src_linesize + (i-2)*src_stride] + srcp[2*src_linesize + (i-2)*src_stride]) * 2
+ (srcp[-2*src_linesize + (i-1)*src_stride] + srcp[2*src_linesize + (i-1)*src_stride]) * 4 + (srcp[-2*src_linesize + (i-1)*src_stride] + srcp[2*src_linesize + (i-1)*src_stride]) * 4
@ -106,12 +112,15 @@ void fn(gaussian_blur)(int w, int h,
+ srcp[(i+1)*src_stride] * 12 + srcp[(i+1)*src_stride] * 12
+ srcp[(i+2)*src_stride] * 5) / 159; + srcp[(i+2)*src_stride] * 5) / 159;
} }
dstp[w - 2] = srcp[(w - 2)*src_stride]; for (; i < w; i++)
dstp[w - 1] = srcp[(w - 1)*src_stride]; dstp[i] = srcp[i*src_stride];
dstp += dst_linesize; dstp += dst_linesize;
srcp += src_linesize; srcp += src_linesize;
} }
memcpy(dstp, srcp, w*sizeof(pixel)); dstp += dst_linesize; srcp += src_linesize; for (; j < h; j++) {
memcpy(dstp, srcp, w*sizeof(pixel)); memcpy(dstp, srcp, w*sizeof(pixel));
dstp += dst_linesize;
srcp += src_linesize;
}
} }

Loading…
Cancel
Save