diff options
Diffstat (limited to 'gdk-pixbuf')
-rw-r--r-- | gdk-pixbuf/ChangeLog | 5 | ||||
-rw-r--r-- | gdk-pixbuf/io-jpeg.c | 10 |
2 files changed, 12 insertions, 3 deletions
diff --git a/gdk-pixbuf/ChangeLog b/gdk-pixbuf/ChangeLog index 593ff30c30..0c3da6bfe2 100644 --- a/gdk-pixbuf/ChangeLog +++ b/gdk-pixbuf/ChangeLog @@ -1,3 +1,8 @@ +2007-12-09 Matthias Clasen <mclasen@redhat.com> + + * io-jpeg.c: Fix the spinguard logic for big buffers. + (#494667, Ed Catmur) + 2007-11-25 Tor Lillqvist <tml@novell.com> * Makefile.am: Fix static build of the icns loader. diff --git a/gdk-pixbuf/io-jpeg.c b/gdk-pixbuf/io-jpeg.c index fdcc3e2cb4..7df7e1cd5c 100644 --- a/gdk-pixbuf/io-jpeg.c +++ b/gdk-pixbuf/io-jpeg.c @@ -812,7 +812,7 @@ gdk_pixbuf__jpeg_image_load_increment (gpointer data, struct jpeg_decompress_struct *cinfo; my_src_ptr src; guint num_left, num_copy; - guint last_bytes_left; + guint last_num_left, last_bytes_left; guint spinguard; gboolean first; const guchar *bufhd; @@ -853,6 +853,7 @@ gdk_pixbuf__jpeg_image_load_increment (gpointer data, if (num_left == 0) return TRUE; + last_num_left = num_left; last_bytes_left = 0; spinguard = 0; first = TRUE; @@ -880,10 +881,13 @@ gdk_pixbuf__jpeg_image_load_increment (gpointer data, if (first) { last_bytes_left = src->pub.bytes_in_buffer; first = FALSE; - } else if (src->pub.bytes_in_buffer == last_bytes_left) + } else if (src->pub.bytes_in_buffer == last_bytes_left + && num_left == last_num_left) { spinguard++; - else + } else { last_bytes_left = src->pub.bytes_in_buffer; + last_num_left = num_left; + } /* should not go through twice and not pull bytes out of buf */ if (spinguard > 2) |