diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/sna/sna_composite.c | 58 |
1 files changed, 21 insertions, 37 deletions
diff --git a/src/sna/sna_composite.c b/src/sna/sna_composite.c index 38ff99de..a610e7cd 100644 --- a/src/sna/sna_composite.c +++ b/src/sna/sna_composite.c @@ -781,45 +781,29 @@ sna_composite_rectangles(CARD8 op, /* Clearing a pixmap after creation is a common operation, so take * advantage and reduce further damage operations. */ + if (region.data == NULL && + region.extents.x2 - region.extents.x1 == pixmap->drawable.width && + region.extents.y2 - region.extents.y1 == pixmap->drawable.height) { + sna_damage_all(&priv->gpu_damage, + pixmap->drawable.width, pixmap->drawable.height); + priv->undamaged = false; + if (op <= PictOpSrc) { + priv->clear = true; + priv->clear_color = 0; + if (op == PictOpSrc) + sna_get_pixel_from_rgba(&priv->clear_color, + color->red, + color->green, + color->blue, + color->alpha, + dst->format); + DBG(("%s: marking clear [%08x]\n", + __FUNCTION__, priv->clear_color)); + } + } if (!DAMAGE_IS_ALL(priv->gpu_damage)) { assert_pixmap_contains_box(pixmap, RegionExtents(®ion)); - - if (region.data == NULL && - region.extents.x2 - region.extents.x1 == pixmap->drawable.width && - region.extents.y2 - region.extents.y1 == pixmap->drawable.height) { - sna_damage_all(&priv->gpu_damage, - pixmap->drawable.width, pixmap->drawable.height); - priv->undamaged = false; - if (op <= PictOpSrc) { - priv->clear = true; - priv->clear_color = 0; - if (op == PictOpSrc) - sna_get_pixel_from_rgba(&priv->clear_color, - color->red, - color->green, - color->blue, - color->alpha, - dst->format); - DBG(("%s: marking clear [%08x]\n", - __FUNCTION__, priv->clear_color)); - } - } else - sna_damage_add(&priv->gpu_damage, ®ion); - } else if (op <= PictOpSrc && - region.data == NULL && - region.extents.x2 - region.extents.x1 == pixmap->drawable.width && - region.extents.y2 - region.extents.y1 == pixmap->drawable.height) { - priv->clear = true; - priv->clear_color = 0; - if (op == PictOpSrc) - sna_get_pixel_from_rgba(&priv->clear_color, - color->red, - color->green, - color->blue, - color->alpha, - dst->format); - DBG(("%s: marking clear [%08x]\n", - __FUNCTION__, priv->clear_color)); + sna_damage_add(&priv->gpu_damage, ®ion); } goto done; |