From 150458c402f2a93e87924dacd3d0e99def512b85 Mon Sep 17 00:00:00 2001 From: Chris Wilson Date: Thu, 1 May 2014 09:42:07 +0100 Subject: sna: Refactor migration DBG code And add a new DBG option to disable partial-cpu migrations. Signed-off-by: Chris Wilson --- src/sna/sna_accel.c | 35 +++++++---------------------------- 1 file changed, 7 insertions(+), 28 deletions(-) (limited to 'src') diff --git a/src/sna/sna_accel.c b/src/sna/sna_accel.c index 7efaba80..ef7f842d 100644 --- a/src/sna/sna_accel.c +++ b/src/sna/sna_accel.c @@ -78,6 +78,7 @@ #define UNDO 1 #define MIGRATE_ALL 0 +#define DBG_NO_PARTIAL_MOVE_TO_CPU 0 #define DBG_NO_CPU_UPLOAD 0 #define DBG_NO_CPU_DOWNLOAD 0 @@ -2394,6 +2395,12 @@ sna_drawable_move_region_to_cpu(DrawablePtr drawable, if (box_empty(®ion->extents)) return true; + if (MIGRATE_ALL || DBG_NO_PARTIAL_MOVE_TO_CPU) { + if (!region_subsumes_pixmap(region, pixmap)) + flags |= MOVE_READ; + return _sna_pixmap_move_to_cpu(pixmap, flags); + } + priv = sna_pixmap(pixmap); if (priv == NULL) { DBG(("%s: not attached to pixmap %ld (depth %d)\n", @@ -2732,34 +2739,6 @@ sna_drawable_move_region_to_cpu(DrawablePtr drawable, goto done; } - if (MIGRATE_ALL && priv->gpu_damage) { - BoxPtr box; - int n = sna_damage_get_boxes(priv->gpu_damage, &box); - if (n) { - bool ok; - - DBG(("%s: forced migration\n", __FUNCTION__)); - - assert(pixmap_contains_damage(pixmap, priv->gpu_damage)); - assert(priv->gpu_bo); - - ok = false; - if (use_cpu_bo_for_download(sna, priv, n, box)) { - DBG(("%s: using CPU bo for download from GPU\n", __FUNCTION__)); - ok = sna->render.copy_boxes(sna, GXcopy, - pixmap, priv->gpu_bo, 0, 0, - pixmap, priv->cpu_bo, 0, 0, - box, n, COPY_LAST); - } - if (!ok) { - assert(has_coherent_ptr(sna, sna_pixmap(pixmap), MOVE_READ)); - sna_read_boxes(sna, pixmap, priv->gpu_bo, - box, n); - } - } - sna_damage_destroy(&priv->gpu_damage); - } - if (priv->gpu_damage && (DAMAGE_IS_ALL(priv->gpu_damage) || sna_damage_overlaps_box(priv->gpu_damage, ®ion->extents))) { -- cgit v1.2.3