Blame 0416-qxl-remove-flipped.patch

56753f
From f9344933bcc1425cf1e8142dc2f8321522dc00af Mon Sep 17 00:00:00 2001
56753f
From: Alon Levy <alevy@redhat.com>
56753f
Date: Fri, 24 Feb 2012 23:19:29 +0200
56753f
Subject: [PATCH 416/434] qxl: remove flipped
56753f
56753f
Tested on linux and windows guests. For negative stride, qxl_flip copies
56753f
directly to vga->ds->surface->data, for positive it's reallocated to
56753f
share qxl->guest_primary.data
56753f
56753f
Signed-off-by: Alon Levy <alevy@redhat.com>
56753f
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
56753f
---
56753f
 hw/qxl-render.c |   66 +++++++++++++++++++++++++------------------------------
56753f
 hw/qxl.h        |    2 +-
56753f
 2 files changed, 31 insertions(+), 37 deletions(-)
56753f
56753f
diff --git a/hw/qxl-render.c b/hw/qxl-render.c
56753f
index a7891b2..5811d74 100644
56753f
--- a/hw/qxl-render.c
56753f
+++ b/hw/qxl-render.c
56753f
@@ -23,10 +23,21 @@
56753f
 
56753f
 static void qxl_flip(PCIQXLDevice *qxl, QXLRect *rect)
56753f
 {
56753f
-    uint8_t *src = qxl->guest_primary.data;
56753f
-    uint8_t *dst = qxl->guest_primary.flipped;
56753f
+    uint8_t *src;
56753f
+    uint8_t *dst = qxl->vga.ds->surface->data;
56753f
     int len, i;
56753f
 
56753f
+    if (qxl->guest_primary.qxl_stride > 0) {
56753f
+        return;
56753f
+    }
56753f
+    if (!qxl->guest_primary.data) {
56753f
+        dprint(qxl, 1, "%s: initializing guest_primary.data\n", __func__);
56753f
+        qxl->guest_primary.data = memory_region_get_ram_ptr(&qxl->vga.vram);
56753f
+    }
56753f
+    dprint(qxl, 1, "%s: stride %d, [%d, %d, %d, %d]\n", __func__,
56753f
+            qxl->guest_primary.qxl_stride,
56753f
+            rect->left, rect->right, rect->top, rect->bottom);
56753f
+    src = qxl->guest_primary.data;
56753f
     src += (qxl->guest_primary.surface.height - rect->top - 1) *
56753f
         qxl->guest_primary.abs_stride;
56753f
     dst += rect->top  * qxl->guest_primary.abs_stride;
56753f
@@ -75,52 +86,38 @@ void qxl_render_update(PCIQXLDevice *qxl)
56753f
 {
56753f
     VGACommonState *vga = &qxl->vga;
56753f
     QXLRect dirty[32], update;
56753f
-    void *ptr;
56753f
     int i, redraw = 0;
56753f
-
56753f
-    if (!is_buffer_shared(vga->ds->surface)) {
56753f
-        dprint(qxl, 1, "%s: restoring shared displaysurface\n", __func__);
56753f
-        qxl->guest_primary.resized++;
56753f
-        qxl->guest_primary.commands++;
56753f
-        redraw = 1;
56753f
-    }
56753f
+    DisplaySurface *surface = vga->ds->surface;
56753f
 
56753f
     if (qxl->guest_primary.resized) {
56753f
         qxl->guest_primary.resized = 0;
56753f
 
56753f
-        if (qxl->guest_primary.flipped) {
56753f
-            g_free(qxl->guest_primary.flipped);
56753f
-            qxl->guest_primary.flipped = NULL;
56753f
-        }
56753f
-        qemu_free_displaysurface(vga->ds);
56753f
-
56753f
         qxl->guest_primary.data = memory_region_get_ram_ptr(&qxl->vga.vram);
56753f
-        if (qxl->guest_primary.qxl_stride < 0) {
56753f
-            /* spice surface is upside down -> need extra buffer to flip */
56753f
-            qxl->guest_primary.flipped =
56753f
-                g_malloc(qxl->guest_primary.surface.width *
56753f
-                         qxl->guest_primary.abs_stride);
56753f
-            ptr = qxl->guest_primary.flipped;
56753f
-        } else {
56753f
-            ptr = qxl->guest_primary.data;
56753f
-        }
56753f
-        dprint(qxl, 1, "%s: %dx%d, stride %d, bpp %d, depth %d, flip %s\n",
56753f
+        dprint(qxl, 1, "%s: %dx%d, stride %d, bpp %d, depth %d\n",
56753f
                __FUNCTION__,
56753f
                qxl->guest_primary.surface.width,
56753f
                qxl->guest_primary.surface.height,
56753f
                qxl->guest_primary.qxl_stride,
56753f
                qxl->guest_primary.bytes_pp,
56753f
-               qxl->guest_primary.bits_pp,
56753f
-               qxl->guest_primary.flipped ? "yes" : "no");
56753f
-        vga->ds->surface =
56753f
+               qxl->guest_primary.bits_pp);
56753f
+    }
56753f
+    if (surface->width != qxl->guest_primary.surface.width ||
56753f
+        surface->height != qxl->guest_primary.surface.height) {
56753f
+        dprint(qxl, 1, "%s: resizing displaysurface to guest_primary\n",
56753f
+               __func__);
56753f
+        if (qxl->guest_primary.qxl_stride > 0) {
56753f
+            qemu_free_displaysurface(vga->ds);
56753f
             qemu_create_displaysurface_from(qxl->guest_primary.surface.width,
56753f
                                             qxl->guest_primary.surface.height,
56753f
                                             qxl->guest_primary.bits_pp,
56753f
                                             qxl->guest_primary.abs_stride,
56753f
-                                            ptr);
56753f
-        dpy_resize(vga->ds);
56753f
+                                            qxl->guest_primary.data);
56753f
+        } else {
56753f
+            qemu_resize_displaysurface(vga->ds,
56753f
+                    qxl->guest_primary.surface.width,
56753f
+                    qxl->guest_primary.surface.height);
56753f
+        }
56753f
     }
56753f
-
56753f
     update.left   = 0;
56753f
     update.right  = qxl->guest_primary.surface.width;
56753f
     update.top    = 0;
56753f
@@ -136,14 +133,11 @@ void qxl_render_update(PCIQXLDevice *qxl)
56753f
         memset(dirty, 0, sizeof(dirty));
56753f
         dirty[0] = update;
56753f
     }
56753f
-
56753f
     for (i = 0; i < ARRAY_SIZE(dirty); i++) {
56753f
         if (qemu_spice_rect_is_empty(dirty+i)) {
56753f
             break;
56753f
         }
56753f
-        if (qxl->guest_primary.flipped) {
56753f
-            qxl_flip(qxl, dirty+i);
56753f
-        }
56753f
+        qxl_flip(qxl, dirty+i);
56753f
         dpy_update(vga->ds,
56753f
                    dirty[i].left, dirty[i].top,
56753f
                    dirty[i].right - dirty[i].left,
56753f
diff --git a/hw/qxl.h b/hw/qxl.h
56753f
index 9288e46..53a3ace 100644
56753f
--- a/hw/qxl.h
56753f
+++ b/hw/qxl.h
56753f
@@ -52,7 +52,7 @@ typedef struct PCIQXLDevice {
56753f
         uint32_t       abs_stride;
56753f
         uint32_t       bits_pp;
56753f
         uint32_t       bytes_pp;
56753f
-        uint8_t        *data, *flipped;
56753f
+        uint8_t        *data;
56753f
     } guest_primary;
56753f
 
56753f
     struct surfaces {
56753f
-- 
56753f
1.7.10
56753f