diff options
-rw-r--r-- | src/sna/gen2_render.c | 27 | ||||
-rw-r--r-- | src/sna/gen3_render.c | 33 |
2 files changed, 5 insertions, 55 deletions
diff --git a/src/sna/gen2_render.c b/src/sna/gen2_render.c index b539a815..ef7b9854 100644 --- a/src/sna/gen2_render.c +++ b/src/sna/gen2_render.c @@ -1593,32 +1593,7 @@ gen2_composite_set_target(struct sna *sna, if (op->dst.bo == NULL) return false; - if (op->dst.bo->pitch < 8) { - struct sna_pixmap *priv; - struct kgem_bo *bo; - - priv = sna_pixmap_move_to_gpu (op->dst.pixmap, - MOVE_READ | MOVE_WRITE); - if (priv == NULL || priv->pinned) - return false; - - assert(op->dst.bo == priv->gpu_bo); - bo = kgem_replace_bo(&sna->kgem, priv->gpu_bo, - op->dst.width, op->dst.height, 8, - op->dst.pixmap->drawable.bitsPerPixel); - if (bo == NULL) - return false; - - sna_pixmap_unmap(op->dst.pixmap, priv); - kgem_bo_destroy(&sna->kgem, priv->gpu_bo); - priv->gpu_bo = bo; - - 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; - } + assert((op->dst.bo->pitch & 7) == 0); get_drawable_deltas(dst->pDrawable, op->dst.pixmap, &op->dst.x, &op->dst.y); diff --git a/src/sna/gen3_render.c b/src/sna/gen3_render.c index 348cb862..58e62040 100644 --- a/src/sna/gen3_render.c +++ b/src/sna/gen3_render.c @@ -3178,36 +3178,11 @@ gen3_composite_set_target(struct sna *sna, /* For single-stream mode there should be no minimum alignment * required, except that the width must be at least 2 elements. + * Furthermore, it appears that the pitch must be a multiple of + * 2 elements. */ - if (op->dst.bo->pitch < 2*op->dst.pixmap->drawable.bitsPerPixel) { - struct sna_pixmap *priv; - - priv = sna_pixmap_move_to_gpu (op->dst.pixmap, - MOVE_READ | MOVE_WRITE); - if (priv == NULL || priv->pinned) - return false; - - if (priv->gpu_bo->pitch < 2*op->dst.pixmap->drawable.bitsPerPixel) { - struct kgem_bo *bo; - - 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; - - sna_pixmap_unmap(op->dst.pixmap, priv); - kgem_bo_destroy(&sna->kgem, priv->gpu_bo); - priv->gpu_bo = bo; - } - - 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; - } + if (op->dst.bo->pitch & ((2*op->dst.pixmap->drawable.bitsPerPixel >> 3) - 1)) + return false; get_drawable_deltas(dst->pDrawable, op->dst.pixmap, &op->dst.x, &op->dst.y); |