diff options
author | Chris Wilson <chris@chris-wilson.co.uk> | 2012-01-26 11:20:03 +0000 |
---|---|---|
committer | Chris Wilson <chris@chris-wilson.co.uk> | 2012-01-26 13:01:24 +0000 |
commit | 35c0ef586bf508c577642d772f18eae0b64cfd44 (patch) | |
tree | c5188f6e3dbe5f50aa6f5c52a27747cb9e9c6f6f | |
parent | b76a6da3fa0148ef32600dd9505e22b90de037df (diff) |
sna/gen3: Use cpu bo if already in use
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
-rw-r--r-- | src/sna/gen3_render.c | 60 |
1 files changed, 37 insertions, 23 deletions
diff --git a/src/sna/gen3_render.c b/src/sna/gen3_render.c index 95a79b2b..af83966d 100644 --- a/src/sna/gen3_render.c +++ b/src/sna/gen3_render.c @@ -2337,32 +2337,42 @@ gen3_composite_set_target(struct sna *sna, op->dst.height = op->dst.pixmap->drawable.height; priv = sna_pixmap(op->dst.pixmap); - priv = sna_pixmap_force_to_gpu(op->dst.pixmap, MOVE_READ | MOVE_WRITE); - if (priv == NULL) - return FALSE; + op->dst.bo = NULL; + priv = sna_pixmap(op->dst.pixmap); + if (priv && + priv->gpu_bo == NULL && + priv->cpu_bo && priv->cpu_bo->domain != DOMAIN_CPU) { + op->dst.bo = priv->cpu_bo; + op->damage = &priv->cpu_damage; + } + if (op->dst.bo == NULL) { + priv = sna_pixmap_force_to_gpu(op->dst.pixmap, MOVE_READ | MOVE_WRITE); + if (priv == NULL) + return FALSE; - /* For single-stream mode there should be no minimum alignment - * required, except that the width must be at least 2 elements. - */ - if (priv->gpu_bo->pitch < 2*op->dst.pixmap->drawable.bitsPerPixel) { - struct kgem_bo *bo; + /* For single-stream mode there should be no minimum alignment + * required, except that the width must be at least 2 elements. + */ + if (priv->gpu_bo->pitch < 2*op->dst.pixmap->drawable.bitsPerPixel) { + struct kgem_bo *bo; - if (priv->pinned) - return FALSE; + if (priv->pinned) + return FALSE; - bo = kgem_replace_bo(&sna->kgem, priv->gpu_bo, - op->dst.width, op->dst.height, - 2*op->dst.pixmap->drawable.bitsPerPixel, - op->dst.pixmap->drawable.bitsPerPixel); - if (bo == NULL) - return FALSE; + bo = kgem_replace_bo(&sna->kgem, priv->gpu_bo, + op->dst.width, op->dst.height, + 2*op->dst.pixmap->drawable.bitsPerPixel, + op->dst.pixmap->drawable.bitsPerPixel); + if (bo == NULL) + return FALSE; - kgem_bo_destroy(&sna->kgem, priv->gpu_bo); - priv->gpu_bo = bo; - } + kgem_bo_destroy(&sna->kgem, priv->gpu_bo); + priv->gpu_bo = bo; + } - op->dst.bo = priv->gpu_bo; - op->damage = &priv->gpu_damage; + op->dst.bo = priv->gpu_bo; + op->damage = &priv->gpu_damage; + } if (sna_damage_is_all(op->damage, op->dst.width, op->dst.height)) op->damage = NULL; @@ -2475,7 +2485,9 @@ gen3_composite_fallback(struct sna *sna, if (src_pixmap && !is_solid(src) && !source_fallback(src)) { priv = sna_pixmap(src_pixmap); - if (priv && priv->gpu_damage && !priv->cpu_damage) { + if (priv && + ((priv->gpu_damage && !priv->cpu_damage) || + (priv->cpu_bo && priv->cpu_bo->domain != DOMAIN_CPU))) { DBG(("%s: src is already on the GPU, try to use GPU\n", __FUNCTION__)); return FALSE; @@ -2483,7 +2495,9 @@ gen3_composite_fallback(struct sna *sna, } if (mask_pixmap && !is_solid(mask) && !source_fallback(mask)) { priv = sna_pixmap(mask_pixmap); - if (priv && priv->gpu_damage && !priv->cpu_damage) { + if (priv && + ((priv->gpu_damage && !priv->cpu_damage) || + (priv->cpu_bo && priv->cpu_bo->domain != DOMAIN_CPU))) { DBG(("%s: mask is already on the GPU, try to use GPU\n", __FUNCTION__)); return FALSE; |