Blame 0517-spice-raise-requirement-to-0.12.patch

64c339
From be955ad2a04cb7be9b5f34cd0e43d29f34113c6e Mon Sep 17 00:00:00 2001
64c339
From: Gerd Hoffmann <kraxel@redhat.com>
64c339
Date: Mon, 24 Sep 2012 10:23:40 +0200
64c339
Subject: [PATCH 517/647] spice: raise requirement to 0.12
64c339
64c339
With the next qemu version (1.3) we are going to bump the qxl device
64c339
revision to 4.  The new features available require a recent spice-server
64c339
version, so raise up the bar.  Otherwise we would end up with different
64c339
qxl revisions depending on the spice-server version installed, which
64c339
would be a major PITA when it comes to compat properties.
64c339
64c339
Clear out a big bunch of #ifdefs which are not needed any more.
64c339
64c339
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
64c339
---
64c339
 configure          | 18 ++----------------
64c339
 hw/qxl.c           | 30 ------------------------------
64c339
 ui/spice-core.c    | 51 ++-------------------------------------------------
64c339
 ui/spice-display.c | 38 --------------------------------------
64c339
 ui/spice-display.h |  5 -----
64c339
 5 files changed, 4 insertions(+), 138 deletions(-)
64c339
64c339
diff --git a/configure b/configure
64c339
index ebe8b1c..b843d20 100755
64c339
--- a/configure
64c339
+++ b/configure
64c339
@@ -2705,20 +2705,14 @@ int main(void) { spice_server_new(); return 0; }
64c339
 EOF
64c339
   spice_cflags=$($pkg_config --cflags spice-protocol spice-server 2>/dev/null)
64c339
   spice_libs=$($pkg_config --libs spice-protocol spice-server 2>/dev/null)
64c339
-  if $pkg_config --atleast-version=0.8.2 spice-server >/dev/null 2>&1 && \
64c339
-     $pkg_config --atleast-version=0.8.1 spice-protocol > /dev/null 2>&1 && \
64c339
+  if $pkg_config --atleast-version=0.12.0 spice-server >/dev/null 2>&1 && \
64c339
+     $pkg_config --atleast-version=0.12.2 spice-protocol > /dev/null 2>&1 && \
64c339
      compile_prog "$spice_cflags" "$spice_libs" ; then
64c339
     spice="yes"
64c339
     libs_softmmu="$libs_softmmu $spice_libs"
64c339
     QEMU_CFLAGS="$QEMU_CFLAGS $spice_cflags"
64c339
     spice_protocol_version=$($pkg_config --modversion spice-protocol)
64c339
     spice_server_version=$($pkg_config --modversion spice-server)
64c339
-    if $pkg_config --atleast-version=0.12.0 spice-protocol >/dev/null 2>&1; then
64c339
-        spice_qxl_io_monitors_config_async="yes"
64c339
-    fi
64c339
-    if $pkg_config --atleast-version=0.12.2 spice-protocol > /dev/null 2>&1; then
64c339
-        spice_qxl_client_monitors_config="yes"
64c339
-    fi
64c339
   else
64c339
     if test "$spice" = "yes" ; then
64c339
       feature_not_found "spice"
64c339
@@ -3456,14 +3450,6 @@ if test "$spice" = "yes" ; then
64c339
   echo "CONFIG_SPICE=y" >> $config_host_mak
64c339
 fi
64c339
 
64c339
-if test "$spice_qxl_io_monitors_config_async" = "yes" ; then
64c339
-  echo "CONFIG_QXL_IO_MONITORS_CONFIG_ASYNC=y" >> $config_host_mak
64c339
-fi
64c339
-
64c339
-if test "$spice_qxl_client_monitors_config" = "yes" ; then
64c339
-  echo "CONFIG_QXL_CLIENT_MONITORS_CONFIG=y" >> $config_host_mak
64c339
-fi
64c339
-
64c339
 if test "$smartcard" = "yes" ; then
64c339
   echo "CONFIG_SMARTCARD=y" >> $config_host_mak
64c339
 fi
64c339
diff --git a/hw/qxl.c b/hw/qxl.c
64c339
index 5a9bf1c..255fdf4 100644
64c339
--- a/hw/qxl.c
64c339
+++ b/hw/qxl.c
64c339
@@ -29,11 +29,6 @@
64c339
 
64c339
 #include "qxl.h"
64c339
 
64c339
-#ifndef CONFIG_QXL_IO_MONITORS_CONFIG_ASYNC
64c339
-/* spice-protocol is too old, add missing definitions */
64c339
-#define QXL_IO_MONITORS_CONFIG_ASYNC (QXL_IO_FLUSH_RELEASE + 1)
64c339
-#endif
64c339
-
64c339
 /*
64c339
  * NOTE: SPICE_RING_PROD_ITEM accesses memory on the pci bar and as
64c339
  * such can be changed by the guest, so to avoid a guest trigerrable
64c339
@@ -262,9 +257,6 @@ static void qxl_spice_destroy_surfaces(PCIQXLDevice *qxl, qxl_async_io async)
64c339
 static void qxl_spice_monitors_config_async(PCIQXLDevice *qxl, int replay)
64c339
 {
64c339
     trace_qxl_spice_monitors_config(qxl->id);
64c339
-/* 0x000b01 == 0.11.1 */
64c339
-#if SPICE_SERVER_VERSION >= 0x000b01 && \
64c339
-    defined(CONFIG_QXL_IO_MONITORS_CONFIG_ASYNC)
64c339
     if (replay) {
64c339
         /*
64c339
          * don't use QXL_COOKIE_TYPE_IO:
64c339
@@ -286,10 +278,6 @@ static void qxl_spice_monitors_config_async(PCIQXLDevice *qxl, int replay)
64c339
                 (uintptr_t)qxl_cookie_new(QXL_COOKIE_TYPE_IO,
64c339
                                           QXL_IO_MONITORS_CONFIG_ASYNC));
64c339
     }
64c339
-#else
64c339
-    fprintf(stderr, "qxl: too old spice-protocol/spice-server for "
64c339
-            "QXL_IO_MONITORS_CONFIG_ASYNC\n");
64c339
-#endif
64c339
 }
64c339
 
64c339
 void qxl_spice_reset_image_cache(PCIQXLDevice *qxl)
64c339
@@ -948,8 +936,6 @@ static void interface_async_complete(QXLInstance *sin, uint64_t cookie_token)
64c339
     }
64c339
 }
64c339
 
64c339
-#if SPICE_SERVER_VERSION >= 0x000b04
64c339
-
64c339
 /* called from spice server thread context only */
64c339
 static void interface_set_client_capabilities(QXLInstance *sin,
64c339
                                               uint8_t client_present,
64c339
@@ -971,11 +957,6 @@ static void interface_set_client_capabilities(QXLInstance *sin,
64c339
     qxl_send_events(qxl, QXL_INTERRUPT_CLIENT);
64c339
 }
64c339
 
64c339
-#endif
64c339
-
64c339
-#if defined(CONFIG_QXL_CLIENT_MONITORS_CONFIG) \
64c339
-    && SPICE_SERVER_VERSION >= 0x000b05
64c339
-
64c339
 static uint32_t qxl_crc32(const uint8_t *p, unsigned len)
64c339
 {
64c339
     /*
64c339
@@ -1044,7 +1025,6 @@ static int interface_client_monitors_config(QXLInstance *sin,
64c339
     qxl_send_events(qxl, QXL_INTERRUPT_CLIENT_MONITORS_CONFIG);
64c339
     return 1;
64c339
 }
64c339
-#endif
64c339
 
64c339
 static const QXLInterface qxl_interface = {
64c339
     .base.type               = SPICE_INTERFACE_QXL,
64c339
@@ -1067,13 +1047,8 @@ static const QXLInterface qxl_interface = {
64c339
     .flush_resources         = interface_flush_resources,
64c339
     .async_complete          = interface_async_complete,
64c339
     .update_area_complete    = interface_update_area_complete,
64c339
-#if SPICE_SERVER_VERSION >= 0x000b04
64c339
     .set_client_capabilities = interface_set_client_capabilities,
64c339
-#endif
64c339
-#if SPICE_SERVER_VERSION >= 0x000b05 && \
64c339
-    defined(CONFIG_QXL_CLIENT_MONITORS_CONFIG)
64c339
     .client_monitors_config = interface_client_monitors_config,
64c339
-#endif
64c339
 };
64c339
 
64c339
 static void qxl_enter_vga_mode(PCIQXLDevice *d)
64c339
@@ -1846,7 +1821,6 @@ static void qxl_vm_change_state_handler(void *opaque, int running,
64c339
                                         RunState state)
64c339
 {
64c339
     PCIQXLDevice *qxl = opaque;
64c339
-    qemu_spice_vm_change_state_handler(&qxl->ssd, running, state);
64c339
 
64c339
     if (running) {
64c339
         /*
64c339
@@ -1963,14 +1937,10 @@ static int qxl_init_common(PCIQXLDevice *qxl)
64c339
         pci_device_rev = QXL_REVISION_STABLE_V10;
64c339
         io_size = 32; /* PCI region size must be pow2 */
64c339
         break;
64c339
-/* 0x000b01 == 0.11.1 */
64c339
-#if SPICE_SERVER_VERSION >= 0x000b01 && \
64c339
-        defined(CONFIG_QXL_IO_MONITORS_CONFIG_ASYNC)
64c339
     case 4: /* qxl-4 */
64c339
         pci_device_rev = QXL_REVISION_STABLE_V12;
64c339
         io_size = msb_mask(QXL_IO_RANGE_SIZE * 2 - 1);
64c339
         break;
64c339
-#endif
64c339
     default:
64c339
         error_report("Invalid revision %d for qxl device (max %d)",
64c339
                      qxl->revision, QXL_DEFAULT_REVISION);
64c339
diff --git a/ui/spice-core.c b/ui/spice-core.c
64c339
index ba0d0bd..5147365 100644
64c339
--- a/ui/spice-core.c
64c339
+++ b/ui/spice-core.c
64c339
@@ -223,7 +223,6 @@ static void channel_event(int event, SpiceChannelEventInfo *info)
64c339
     client = qdict_new();
64c339
     server = qdict_new();
64c339
 
64c339
-#ifdef SPICE_CHANNEL_EVENT_FLAG_ADDR_EXT
64c339
     if (info->flags & SPICE_CHANNEL_EVENT_FLAG_ADDR_EXT) {
64c339
         add_addr_info(client, (struct sockaddr *)&info->paddr_ext,
64c339
                       info->plen_ext);
64c339
@@ -232,12 +231,7 @@ static void channel_event(int event, SpiceChannelEventInfo *info)
64c339
     } else {
64c339
         error_report("spice: %s, extended address is expected",
64c339
                      __func__);
64c339
-#endif
64c339
-        add_addr_info(client, &info->paddr, info->plen);
64c339
-        add_addr_info(server, &info->laddr, info->llen);
64c339
-#ifdef SPICE_CHANNEL_EVENT_FLAG_ADDR_EXT
64c339
     }
64c339
-#endif
64c339
 
64c339
     if (event == SPICE_CHANNEL_EVENT_INITIALIZED) {
64c339
         qdict_put(server, "auth", qstring_from_str(auth));
64c339
@@ -276,7 +270,6 @@ static SpiceCoreInterface core_interface = {
64c339
     .channel_event      = channel_event,
64c339
 };
64c339
 
64c339
-#ifdef SPICE_INTERFACE_MIGRATION
64c339
 typedef struct SpiceMigration {
64c339
     SpiceMigrateInstance sin;
64c339
     struct {
64c339
@@ -313,7 +306,6 @@ static void migrate_end_complete_cb(SpiceMigrateInstance *sin)
64c339
     monitor_protocol_event(QEVENT_SPICE_MIGRATE_COMPLETED, NULL);
64c339
     spice_migration_completed = true;
64c339
 }
64c339
-#endif
64c339
 
64c339
 /* config string parsing */
64c339
 
64c339
@@ -393,17 +385,13 @@ static SpiceChannelList *qmp_query_spice_channels(void)
64c339
         chan = g_malloc0(sizeof(*chan));
64c339
         chan->value = g_malloc0(sizeof(*chan->value));
64c339
 
64c339
-#ifdef SPICE_CHANNEL_EVENT_FLAG_ADDR_EXT
64c339
         if (item->info->flags & SPICE_CHANNEL_EVENT_FLAG_ADDR_EXT) {
64c339
             paddr = (struct sockaddr *)&item->info->paddr_ext;
64c339
             plen = item->info->plen_ext;
64c339
         } else {
64c339
-#endif
64c339
             paddr = &item->info->paddr;
64c339
             plen = item->info->plen;
64c339
-#ifdef SPICE_CHANNEL_EVENT_FLAG_ADDR_EXT
64c339
         }
64c339
-#endif
64c339
 
64c339
         getnameinfo(paddr, plen,
64c339
                     host, sizeof(host), port, sizeof(port),
64c339
@@ -473,13 +461,10 @@ SpiceInfo *qmp_query_spice(Error **errp)
64c339
         info->tls_port = tls_port;
64c339
     }
64c339
 
64c339
-#if SPICE_SERVER_VERSION >= 0x000a03 /* 0.10.3 */
64c339
     info->mouse_mode = spice_server_is_server_mouse(spice_server) ?
64c339
                        SPICE_QUERY_MOUSE_MODE_SERVER :
64c339
                        SPICE_QUERY_MOUSE_MODE_CLIENT;
64c339
-#else
64c339
-    info->mouse_mode = SPICE_QUERY_MOUSE_MODE_UNKNOWN;
64c339
-#endif
64c339
+
64c339
     /* for compatibility with the original command */
64c339
     info->has_channels = true;
64c339
     info->channels = qmp_query_spice_channels();
64c339
@@ -492,19 +477,11 @@ static void migration_state_notifier(Notifier *notifier, void *data)
64c339
     MigrationState *s = data;
64c339
 
64c339
     if (migration_is_active(s)) {
64c339
-#ifdef SPICE_INTERFACE_MIGRATION
64c339
         spice_server_migrate_start(spice_server);
64c339
-#endif
64c339
     } else if (migration_has_finished(s)) {
64c339
-#ifndef SPICE_INTERFACE_MIGRATION
64c339
-        spice_server_migrate_switch(spice_server);
64c339
-        monitor_protocol_event(QEVENT_SPICE_MIGRATE_COMPLETED, NULL);
64c339
-        spice_migration_completed = true;
64c339
-#else
64c339
         spice_server_migrate_end(spice_server, true);
64c339
     } else if (migration_has_failed(s)) {
64c339
         spice_server_migrate_end(spice_server, false);
64c339
-#endif
64c339
     }
64c339
 }
64c339
 
64c339
@@ -513,16 +490,11 @@ int qemu_spice_migrate_info(const char *hostname, int port, int tls_port,
64c339
                             MonitorCompletion *cb, void *opaque)
64c339
 {
64c339
     int ret;
64c339
-#ifdef SPICE_INTERFACE_MIGRATION
64c339
+
64c339
     spice_migrate.connect_complete.cb = cb;
64c339
     spice_migrate.connect_complete.opaque = opaque;
64c339
     ret = spice_server_migrate_connect(spice_server, hostname,
64c339
                                        port, tls_port, subject);
64c339
-#else
64c339
-    ret = spice_server_migrate_info(spice_server, hostname,
64c339
-                                    port, tls_port, subject);
64c339
-    cb(opaque, NULL);
64c339
-#endif
64c339
     return ret;
64c339
 }
64c339
 
64c339
@@ -561,7 +533,6 @@ static int add_channel(const char *name, const char *value, void *opaque)
64c339
 static void vm_change_state_handler(void *opaque, int running,
64c339
                                     RunState state)
64c339
 {
64c339
-#if SPICE_SERVER_VERSION >= 0x000b02 /* 0.11.2 */
64c339
     if (running) {
64c339
         qemu_spice_display_start();
64c339
         spice_server_vm_start(spice_server);
64c339
@@ -569,7 +540,6 @@ static void vm_change_state_handler(void *opaque, int running,
64c339
         spice_server_vm_stop(spice_server);
64c339
         qemu_spice_display_stop();
64c339
     }
64c339
-#endif
64c339
 }
64c339
 
64c339
 void qemu_spice_init(void)
64c339
@@ -585,9 +555,7 @@ void qemu_spice_init(void)
64c339
     int port, tls_port, len, addr_flags;
64c339
     spice_image_compression_t compression;
64c339
     spice_wan_compression_t wan_compr;
64c339
-#if SPICE_SERVER_VERSION >= 0x000b02 /* 0.11.2 */
64c339
     bool seamless_migration;
64c339
-#endif
64c339
 
64c339
     qemu_thread_get_self(&me);
64c339
 
64c339
@@ -672,16 +640,11 @@ void qemu_spice_init(void)
64c339
         spice_server_set_ticket(spice_server, password, 0, 0, 0);
64c339
     }
64c339
     if (qemu_opt_get_bool(opts, "sasl", 0)) {
64c339
-#if SPICE_SERVER_VERSION >= 0x000900 /* 0.9.0 */
64c339
         if (spice_server_set_sasl_appname(spice_server, "qemu") == -1 ||
64c339
             spice_server_set_sasl(spice_server, 1) == -1) {
64c339
             error_report("spice: failed to enable sasl");
64c339
             exit(1);
64c339
         }
64c339
-#else
64c339
-        error_report("spice: sasl is not available (spice >= 0.9 required)");
64c339
-        exit(1);
64c339
-#endif
64c339
     }
64c339
     if (qemu_opt_get_bool(opts, "disable-ticketing", 0)) {
64c339
         auth = "none";
64c339
@@ -726,15 +689,11 @@ void qemu_spice_init(void)
64c339
 
64c339
     qemu_opt_foreach(opts, add_channel, &tls_port, 0);
64c339
 
64c339
-#if SPICE_SERVER_VERSION >= 0x000a02 /* 0.10.2 */
64c339
     spice_server_set_name(spice_server, qemu_name);
64c339
     spice_server_set_uuid(spice_server, qemu_uuid);
64c339
-#endif
64c339
 
64c339
-#if SPICE_SERVER_VERSION >= 0x000b02 /* 0.11.2 */
64c339
     seamless_migration = qemu_opt_get_bool(opts, "seamless-migration", 0);
64c339
     spice_server_set_seamless_migration(spice_server, seamless_migration);
64c339
-#endif
64c339
     if (0 != spice_server_init(spice_server, &core_interface)) {
64c339
         error_report("failed to initialize spice server");
64c339
         exit(1);
64c339
@@ -743,11 +702,9 @@ void qemu_spice_init(void)
64c339
 
64c339
     migration_state.notify = migration_state_notifier;
64c339
     add_migration_state_change_notifier(&migration_state);
64c339
-#ifdef SPICE_INTERFACE_MIGRATION
64c339
     spice_migrate.sin.base.sif = &migrate_interface.base;
64c339
     spice_migrate.connect_complete.cb = NULL;
64c339
     qemu_spice_add_interface(&spice_migrate.sin.base);
64c339
-#endif
64c339
 
64c339
     qemu_spice_input_init();
64c339
     qemu_spice_audio_init();
64c339
@@ -815,15 +772,11 @@ int qemu_spice_set_pw_expire(time_t expires)
64c339
 
64c339
 int qemu_spice_display_add_client(int csock, int skipauth, int tls)
64c339
 {
64c339
-#if SPICE_SERVER_VERSION >= 0x000a01
64c339
     if (tls) {
64c339
         return spice_server_add_ssl_client(spice_server, csock, skipauth);
64c339
     } else {
64c339
         return spice_server_add_client(spice_server, csock, skipauth);
64c339
     }
64c339
-#else
64c339
-    return -1;
64c339
-#endif
64c339
 }
64c339
 
64c339
 static void spice_register_config(void)
64c339
diff --git a/ui/spice-display.c b/ui/spice-display.c
64c339
index d062765..422e7c4 100644
64c339
--- a/ui/spice-display.c
64c339
+++ b/ui/spice-display.c
64c339
@@ -126,21 +126,6 @@ void qemu_spice_wakeup(SimpleSpiceDisplay *ssd)
64c339
     ssd->worker->wakeup(ssd->worker);
64c339
 }
64c339
 
64c339
-#if SPICE_SERVER_VERSION < 0x000b02 /* before 0.11.2 */
64c339
-static void qemu_spice_start(SimpleSpiceDisplay *ssd)
64c339
-{
64c339
-    trace_qemu_spice_start(ssd->qxl.id);
64c339
-    ssd->worker->start(ssd->worker);
64c339
-}
64c339
-
64c339
-static void qemu_spice_stop(SimpleSpiceDisplay *ssd)
64c339
-{
64c339
-    trace_qemu_spice_stop(ssd->qxl.id);
64c339
-    ssd->worker->stop(ssd->worker);
64c339
-}
64c339
-
64c339
-#else
64c339
-
64c339
 static int spice_display_is_running;
64c339
 
64c339
 void qemu_spice_display_start(void)
64c339
@@ -153,15 +138,9 @@ void qemu_spice_display_stop(void)
64c339
     spice_display_is_running = false;
64c339
 }
64c339
 
64c339
-#endif
64c339
-
64c339
 int qemu_spice_display_is_running(SimpleSpiceDisplay *ssd)
64c339
 {
64c339
-#if SPICE_SERVER_VERSION < 0x000b02 /* before 0.11.2 */
64c339
-    return ssd->running;
64c339
-#else
64c339
     return spice_display_is_running;
64c339
-#endif
64c339
 }
64c339
 
64c339
 static void qemu_spice_create_one_update(SimpleSpiceDisplay *ssd,
64c339
@@ -364,22 +343,6 @@ void qemu_spice_destroy_host_primary(SimpleSpiceDisplay *ssd)
64c339
     qemu_spice_destroy_primary_surface(ssd, 0, QXL_SYNC);
64c339
 }
64c339
 
64c339
-void qemu_spice_vm_change_state_handler(void *opaque, int running,
64c339
-                                        RunState state)
64c339
-{
64c339
-#if SPICE_SERVER_VERSION < 0x000b02 /* before 0.11.2 */
64c339
-    SimpleSpiceDisplay *ssd = opaque;
64c339
-
64c339
-    if (running) {
64c339
-        ssd->running = true;
64c339
-        qemu_spice_start(ssd);
64c339
-    } else {
64c339
-        qemu_spice_stop(ssd);
64c339
-        ssd->running = false;
64c339
-    }
64c339
-#endif
64c339
-}
64c339
-
64c339
 void qemu_spice_display_init_common(SimpleSpiceDisplay *ssd, DisplayState *ds)
64c339
 {
64c339
     ssd->ds = ds;
64c339
@@ -623,7 +586,6 @@ void qemu_spice_display_init(DisplayState *ds)
64c339
     qemu_spice_add_interface(&sdpy.qxl.base);
64c339
     assert(sdpy.worker);
64c339
 
64c339
-    qemu_add_vm_change_state_handler(qemu_spice_vm_change_state_handler, &sdpy);
64c339
     qemu_spice_create_host_memslot(&sdpy);
64c339
     qemu_spice_create_host_primary(&sdpy);
64c339
 }
64c339
diff --git a/ui/spice-display.h b/ui/spice-display.h
64c339
index dea41c1..d766927 100644
64c339
--- a/ui/spice-display.h
64c339
+++ b/ui/spice-display.h
64c339
@@ -83,9 +83,6 @@ struct SimpleSpiceDisplay {
64c339
 
64c339
     QXLRect dirty;
64c339
     int notify;
64c339
-#if SPICE_SERVER_VERSION < 0x000b02 /* before 0.11.2 */
64c339
-    int running;
64c339
-#endif
64c339
 
64c339
     /*
64c339
      * All struct members below this comment can be accessed from
64c339
@@ -133,8 +130,6 @@ void qemu_spice_create_primary_surface(SimpleSpiceDisplay *ssd, uint32_t id,
64c339
 void qemu_spice_destroy_primary_surface(SimpleSpiceDisplay *ssd,
64c339
                                         uint32_t id, qxl_async_io async);
64c339
 void qemu_spice_wakeup(SimpleSpiceDisplay *ssd);
64c339
-#if SPICE_SERVER_VERSION >= 0x000b02 /* before 0.11.2 */
64c339
 void qemu_spice_display_start(void);
64c339
 void qemu_spice_display_stop(void);
64c339
-#endif
64c339
 int qemu_spice_display_is_running(SimpleSpiceDisplay *ssd);
64c339
-- 
64c339
1.7.12.1
64c339