[FFmpeg-devel] [PATCH] lavfi/smptebars: fix invalid writes

Paul B Mahol onemda at gmail.com
Thu Apr 4 16:36:52 CEST 2013


Signed-off-by: Paul B Mahol <onemda at gmail.com>
---
 libavfilter/vsrc_testsrc.c | 22 +++++++++++-----------
 1 file changed, 11 insertions(+), 11 deletions(-)

diff --git a/libavfilter/vsrc_testsrc.c b/libavfilter/vsrc_testsrc.c
index 9317f82..5b1cefc 100644
--- a/libavfilter/vsrc_testsrc.c
+++ b/libavfilter/vsrc_testsrc.c
@@ -721,25 +721,25 @@ static void smptebars_fill_picture(AVFilterContext *ctx, AVFrame *picref)
     for (i = 0; i < 7; i++) {
         DRAW_COLOR(rainbow[i], x, 0,   FFMIN(r_w, test->w - x), r_h);
         DRAW_COLOR(wobnair[i], x, r_h, FFMIN(r_w, test->w - x), w_h);
-        x += r_w;
+        x = FFMIN(test->w, x + r_w);
     }
     x = 0;
     DRAW_COLOR(i_pixel, x, r_h + w_h, p_w, p_h);
-    x += p_w;
+    x = FFMIN(test->w, x + p_w);
     DRAW_COLOR(white, x, r_h + w_h, p_w, p_h);
-    x += p_w;
+    x = FFMIN(test->w, x + p_w);
     DRAW_COLOR(q_pixel, x, r_h + w_h, p_w, p_h);
-    x += p_w;
+    x = FFMIN(test->w, x + p_w);
     tmp = FFALIGN(5 * r_w - x,  1 << pixdesc->log2_chroma_w);
     DRAW_COLOR(black, x, r_h + w_h, tmp, p_h);
-    x += tmp;
+    x = FFMIN(test->w, x + tmp);
     tmp = FFALIGN(r_w / 3,  1 << pixdesc->log2_chroma_w);
-    DRAW_COLOR(neg4ire, x, r_h + w_h, tmp, p_h);
-    x += tmp;
-    DRAW_COLOR(black, x, r_h + w_h, tmp, p_h);
-    x += tmp;
-    DRAW_COLOR(pos4ire, x, r_h + w_h, tmp, p_h);
-    x += tmp;
+    DRAW_COLOR(neg4ire, x, r_h + w_h, FFMIN(tmp, test->w - x), p_h);
+    x = FFMIN(test->w, x + tmp);
+    DRAW_COLOR(black, x, r_h + w_h, FFMIN(tmp, test->w - x), p_h);
+    x = FFMIN(test->w, x + tmp);
+    DRAW_COLOR(pos4ire, x, r_h + w_h, FFMIN(tmp, test->w - x), p_h);
+    x = FFMIN(test->w, x + tmp);
     DRAW_COLOR(black, x, r_h + w_h, test->w - x, p_h);
 }
 
-- 
1.7.11.2



More information about the ffmpeg-devel mailing list