summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChris Wilson <chris@chris-wilson.co.uk>2012-01-26 11:20:03 +0000
committerChris Wilson <chris@chris-wilson.co.uk>2012-01-26 13:01:24 +0000
commit35c0ef586bf508c577642d772f18eae0b64cfd44 (patch)
treec5188f6e3dbe5f50aa6f5c52a27747cb9e9c6f6f
parentb76a6da3fa0148ef32600dd9505e22b90de037df (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.c60
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;