]> Pileus Git - ~andy/gtk/commitdiff
Avoid an FPE for ludicrous scale values
authorMatthias Clasen <mclasen@redhat.com>
Fri, 8 Jan 2010 18:20:28 +0000 (13:20 -0500)
committerMatthias Clasen <mclasen@redhat.com>
Fri, 8 Jan 2010 18:24:33 +0000 (13:24 -0500)
...just bail out early.

gdk-pixbuf/pixops/pixops.c

index 513d16fc8bfce967a31b1b6cc867293a5e8b5579..353021aad3cabce65f17e5d62718a9268ed36bca 100644 (file)
@@ -1251,11 +1251,20 @@ pixops_process (guchar         *dest_buf,
   int i, j;
   int x, y;                    /* X and Y position in source (fixed_point) */
   
-  guchar **line_bufs = g_new (guchar *, filter->y.n);
-  int *filter_weights = make_filter_table (filter);
+  guchar **line_bufs;
+  int *filter_weights;
 
-  int x_step = (1 << SCALE_SHIFT) / scale_x; /* X step in source (fixed point) */
-  int y_step = (1 << SCALE_SHIFT) / scale_y; /* Y step in source (fixed point) */
+  int x_step;
+  int y_step;
+
+  x_step = (1 << SCALE_SHIFT) / scale_x; /* X step in source (fixed point) */
+  y_step = (1 << SCALE_SHIFT) / scale_y; /* Y step in source (fixed point) */
+
+  if (x_step == 0 || y_step == 0)
+    return; /* overflow, bail out */
+
+  line_bufs = g_new (guchar *, filter->y.n);
+  filter_weights = make_filter_table (filter);
 
   int check_shift = check_size ? get_check_shift (check_size) : 0;