diff options
author | Chris Wilson <chris@chris-wilson.co.uk> | 2014-06-17 08:51:00 +0100 |
---|---|---|
committer | Chris Wilson <chris@chris-wilson.co.uk> | 2014-06-17 09:21:25 +0100 |
commit | 96d1fe314c4bb4d862b057a440e575bd32d63460 (patch) | |
tree | ed269429500c05faf7eb8a2c93d0406beee31ce4 /src/sna | |
parent | 30f521c717f7301004e7cb77ba66b840b3f773c6 (diff) |
sna: Add a few missing checks for all-damaged
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Diffstat (limited to 'src/sna')
-rw-r--r-- | src/sna/sna_accel.c | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/src/sna/sna_accel.c b/src/sna/sna_accel.c index f3f95e6d..43fb6b99 100644 --- a/src/sna/sna_accel.c +++ b/src/sna/sna_accel.c @@ -2853,7 +2853,8 @@ move_to_cpu: goto done; } } else { - if (sna_damage_contains_box__no_reduce(priv->cpu_damage, + if (DAMAGE_IS_ALL(priv->cpu_damage) || + sna_damage_contains_box__no_reduce(priv->cpu_damage, ®ion->extents)) { assert(sna_damage_contains_box(&priv->gpu_damage, ®ion->extents) == PIXMAN_REGION_OUT); assert(sna_damage_contains_box(&priv->cpu_damage, ®ion->extents) == PIXMAN_REGION_IN); @@ -3623,7 +3624,8 @@ create_gpu_bo: goto use_gpu_bo; } - if (sna_damage_contains_box__no_reduce(priv->gpu_damage, + if (DAMAGE_IS_ALL(priv->gpu_damage) || + sna_damage_contains_box__no_reduce(priv->gpu_damage, ®ion.extents)) { DBG(("%s: region wholly contained within GPU damage\n", __FUNCTION__)); @@ -3829,6 +3831,7 @@ cpu_fail: sna_damage_destroy(&priv->gpu_damage); *damage = NULL; } else { + assert(!DAMAGE_IS_ALL(priv->cpu_damage)); if (priv->cpu_damage && sna_damage_contains_box__no_reduce(priv->cpu_damage, ®ion.extents)) { @@ -4712,8 +4715,9 @@ try_upload__blt(PixmapPtr pixmap, RegionRec *region, assert(priv->gpu_bo->proxy == NULL); if (priv->cpu_damage && - sna_damage_contains_box__no_reduce(priv->cpu_damage, - ®ion->extents) && + (DAMAGE_IS_ALL(priv->cpu_damage) || + sna_damage_contains_box__no_reduce(priv->cpu_damage, + ®ion->extents)) && !box_inplace(pixmap, ®ion->extents)) { DBG(("%s: no, damage on CPU and too small\n", __FUNCTION__)); return false; |