diff options
author | Chris Wilson <chris@chris-wilson.co.uk> | 2014-02-02 03:52:11 +0000 |
---|---|---|
committer | Chris Wilson <chris@chris-wilson.co.uk> | 2014-02-02 03:52:11 +0000 |
commit | 7f08250a8960f90f6bd34de8c4a17870703bfa60 (patch) | |
tree | bb8b0613de11d61a056a0c51394b9c4a48548c25 /src | |
parent | 853588ad5be9407d2123f6055458ca84e72b8eb9 (diff) |
sna: Reconstruct damage for the partially replaced discarded CPU bo
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Diffstat (limited to 'src')
-rw-r--r-- | src/sna/sna_accel.c | 20 |
1 files changed, 15 insertions, 5 deletions
diff --git a/src/sna/sna_accel.c b/src/sna/sna_accel.c index acf48491..d31fa22a 100644 --- a/src/sna/sna_accel.c +++ b/src/sna/sna_accel.c @@ -2432,7 +2432,7 @@ sna_drawable_move_region_to_cpu(DrawablePtr drawable, if (get_drawable_deltas(drawable, pixmap, &dx, &dy)) RegionTranslate(region, dx, dy); - if (sna->kgem.has_llc && + if (sna->kgem.has_llc && !priv->pinned && sna_pixmap_choose_tiling(pixmap, DEFAULT_TILING) == I915_TILING_NONE) { #ifdef DEBUG_MEMORY @@ -2440,13 +2440,17 @@ sna_drawable_move_region_to_cpu(DrawablePtr drawable, sna->debug_memory.cpu_bo_bytes -= kgem_bo_size(priv->cpu_bo); #endif DBG(("%s: promoting CPU bo to GPU bo\n", __FUNCTION__)); - sna_pixmap_free_gpu(sna, priv); + if (priv->gpu_bo) + sna_pixmap_free_gpu(sna, priv); priv->gpu_bo = priv->cpu_bo; priv->cpu_bo = NULL; priv->ptr = NULL; pixmap->devPrivate.ptr = NULL; - sna_damage_destroy(&priv->cpu_damage); + priv->gpu_damage = priv->cpu_damage; + priv->cpu_damage = NULL; + + discard_gpu = false; } else { DBG(("%s: pushing surrounding damage to GPU bo\n", __FUNCTION__)); sna_damage_subtract(&priv->cpu_damage, region); @@ -2456,6 +2460,12 @@ sna_drawable_move_region_to_cpu(DrawablePtr drawable, if (priv->flush) sna_add_flush_pixmap(sna, priv, priv->gpu_bo); discard_gpu = false; + + assert(priv->cpu_damage == NULL); + sna_damage_all(&priv->gpu_damage, + pixmap->drawable.width, + pixmap->drawable.height); + sna_damage_subtract(&priv->gpu_damage, region); } } sna_damage_add(&priv->cpu_damage, region); @@ -3959,9 +3969,9 @@ sna_pixmap_move_to_gpu(PixmapPtr pixmap, unsigned flags) if (priv->cpu_damage == NULL) goto done; - if (DAMAGE_IS_ALL(priv->cpu_damage) && + if (DAMAGE_IS_ALL(priv->cpu_damage) && priv->cpu_bo && + !priv->pinned && !priv->shm && priv->gpu_bo->tiling == I915_TILING_NONE && - priv->cpu_bo && !priv->shm && kgem_bo_convert_to_gpu(&sna->kgem, priv->cpu_bo, flags)) { assert(!priv->mapped); assert(!IS_STATIC_PTR(priv->ptr)); |