fc5c27b
>From c28ee0e7c851fc58ac6ef8f5137fc35cc55b607c Mon Sep 17 00:00:00 2001
13f703f
From: Gerd Hoffmann <kraxel@redhat.com>
13f703f
Date: Fri, 17 Jun 2011 10:42:25 +0200
fc5c27b
Subject: [PATCH 13/28] spice: add qemu_spice_display_init_common
13f703f
13f703f
Factor out SimpleSpiceDisplay initialization into
13f703f
qemu_spice_display_init_common() and call it from
13f703f
both qxl.c (for vga mode) and spice-display.c
13f703f
13f703f
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
13f703f
---
13f703f
 hw/qxl.c           |    7 +------
13f703f
 ui/spice-display.c |   17 +++++++++++------
13f703f
 ui/spice-display.h |    1 +
13f703f
 3 files changed, 13 insertions(+), 12 deletions(-)
13f703f
13f703f
diff --git a/hw/qxl.c b/hw/qxl.c
13f703f
index 5deb776..2127fa3 100644
13f703f
--- a/hw/qxl.c
13f703f
+++ b/hw/qxl.c
13f703f
@@ -1315,12 +1315,7 @@ static int qxl_init_primary(PCIDevice *dev)
13f703f
 
13f703f
     vga->ds = graphic_console_init(qxl_hw_update, qxl_hw_invalidate,
13f703f
                                    qxl_hw_screen_dump, qxl_hw_text_update, qxl);
13f703f
-    qxl->ssd.ds = vga->ds;
13f703f
-    qemu_mutex_init(&qxl->ssd.lock);
13f703f
-    qxl->ssd.mouse_x = -1;
13f703f
-    qxl->ssd.mouse_y = -1;
13f703f
-    qxl->ssd.bufsize = (16 * 1024 * 1024);
13f703f
-    qxl->ssd.buf = qemu_malloc(qxl->ssd.bufsize);
13f703f
+    qemu_spice_display_init_common(&qxl->ssd, vga->ds);
13f703f
 
13f703f
     qxl0 = qxl;
13f703f
     register_displaychangelistener(vga->ds, &display_listener);
13f703f
diff --git a/ui/spice-display.c b/ui/spice-display.c
13f703f
index 1e6a38f..93e25bf 100644
13f703f
--- a/ui/spice-display.c
13f703f
+++ b/ui/spice-display.c
13f703f
@@ -286,6 +286,16 @@ void qemu_spice_vm_change_state_handler(void *opaque, int running, int reason)
13f703f
     ssd->running = running;
13f703f
 }
13f703f
 
13f703f
+void qemu_spice_display_init_common(SimpleSpiceDisplay *ssd, DisplayState *ds)
13f703f
+{
13f703f
+    ssd->ds = ds;
13f703f
+    qemu_mutex_init(&ssd->lock);
13f703f
+    ssd->mouse_x = -1;
13f703f
+    ssd->mouse_y = -1;
13f703f
+    ssd->bufsize = (16 * 1024 * 1024);
13f703f
+    ssd->buf = qemu_malloc(ssd->bufsize);
13f703f
+}
13f703f
+
13f703f
 /* display listener callbacks */
13f703f
 
13f703f
 void qemu_spice_display_update(SimpleSpiceDisplay *ssd,
13f703f
@@ -499,12 +509,7 @@ static DisplayChangeListener display_listener = {
13f703f
 void qemu_spice_display_init(DisplayState *ds)
13f703f
 {
13f703f
     assert(sdpy.ds == NULL);
13f703f
-    sdpy.ds = ds;
13f703f
-    qemu_mutex_init(&sdpy.lock);
13f703f
-    sdpy.mouse_x = -1;
13f703f
-    sdpy.mouse_y = -1;
13f703f
-    sdpy.bufsize = (16 * 1024 * 1024);
13f703f
-    sdpy.buf = qemu_malloc(sdpy.bufsize);
13f703f
+    qemu_spice_display_init_common(&sdpy, ds);
13f703f
     register_displaychangelistener(ds, &display_listener);
13f703f
 
13f703f
     sdpy.qxl.base.sif = &dpy_interface.base;
13f703f
diff --git a/ui/spice-display.h b/ui/spice-display.h
13f703f
index 5b06b11..eb7a573 100644
13f703f
--- a/ui/spice-display.h
13f703f
+++ b/ui/spice-display.h
13f703f
@@ -75,6 +75,7 @@ void qemu_spice_create_host_memslot(SimpleSpiceDisplay *ssd);
13f703f
 void qemu_spice_create_host_primary(SimpleSpiceDisplay *ssd);
13f703f
 void qemu_spice_destroy_host_primary(SimpleSpiceDisplay *ssd);
13f703f
 void qemu_spice_vm_change_state_handler(void *opaque, int running, int reason);
13f703f
+void qemu_spice_display_init_common(SimpleSpiceDisplay *ssd, DisplayState *ds);
13f703f
 
13f703f
 void qemu_spice_display_update(SimpleSpiceDisplay *ssd,
13f703f
                                int x, int y, int w, int h);
13f703f
-- 
13f703f
1.7.5.1
13f703f