--- /dev/null
+From 7647f29a2a3b69592e38f50890a96d8deeaa2dbb Mon Sep 17 00:00:00 2001\r
+From: Jan Slupski <jslupski@juljas.net>\r
+Date: Fri, 15 Feb 2008 00:55:30 +0100\r
+Subject: [PATCH] Fix for a memory leak in pixman.\r
+\r
+Port of a 1.6 fix for a memory leak in pixman_region_init_rects/pixman_rect_alloc\r
+when the count of boxes is 0.\r
+---\r
+ pixman/src/pixregion.c | 9 +++++++++\r
+ 1 files changed, 9 insertions(+), 0 deletions(-)\r
+\r
+diff --git a/pixman/src/pixregion.c b/pixman/src/pixregion.c\r
+index 1ed3ad7..d6caf6c 100644\r
+--- a/pixman/src/pixregion.c\r
++++ b/pixman/src/pixregion.c\r
+@@ -355,6 +355,15 @@ pixman_region_init_rects(pixman_region16_t *region, pixman_box16_t *boxes, int c\r
+ }\r
+ \r
+ pixman_region_init(region);\r
++\r
++ /* if it's 0, don't call pixman_rect_alloc -- 0 rectangles is\r
++ * a special case, and causing pixman_rect_alloc would cause\r
++ * us to leak memory (because the 0-rect case should be the\r
++ * static pixman_region_emptyData data).\r
++ */\r
++ if (count == 0)\r
++ return PIXMAN_REGION_STATUS_SUCCESS;\r
++\r
+ if (!pixman_rect_alloc(region, count))\r
+ return PIXMAN_REGION_STATUS_FAILURE;\r
+ \r
+