252f3af
>From c169795bed5374f0071af201da2dd32b3c5a2417 Mon Sep 17 00:00:00 2001
252f3af
From: Hans de Goede <hdegoede@redhat.com>
252f3af
Date: Fri, 18 Mar 2011 15:35:27 +0100
252f3af
Subject: [PATCH 17/17] spice-chardev: listen to frontend guest open / close
252f3af
252f3af
Note the vmc_register_interface() in spice_chr_write is left in place
252f3af
in case someone uses spice-chardev with a frontend which does not have
252f3af
guest open / close notification.
252f3af
252f3af
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
252f3af
---
252f3af
 spice-qemu-char.c |   14 ++++++++++++++
252f3af
 1 files changed, 14 insertions(+), 0 deletions(-)
252f3af
252f3af
diff --git a/spice-qemu-char.c b/spice-qemu-char.c
252f3af
index ed7851e..343146c 100644
252f3af
--- a/spice-qemu-char.c
252f3af
+++ b/spice-qemu-char.c
252f3af
@@ -155,6 +155,18 @@ static void spice_chr_close(struct CharDriverState *chr)
252f3af
     qemu_free(s);
252f3af
 }
252f3af
 
252f3af
+static void spice_chr_guest_open(struct CharDriverState *chr)
252f3af
+{
252f3af
+    SpiceCharDriver *s = chr->opaque;
252f3af
+    vmc_register_interface(s);
252f3af
+}
252f3af
+
252f3af
+static void spice_chr_guest_close(struct CharDriverState *chr)
252f3af
+{
252f3af
+    SpiceCharDriver *s = chr->opaque;
252f3af
+    vmc_unregister_interface(s);
252f3af
+}
252f3af
+
252f3af
 static void print_allowed_subtypes(void)
252f3af
 {
252f3af
     const char** psubtype;
252f3af
@@ -207,6 +219,8 @@ CharDriverState *qemu_chr_open_spice(QemuOpts *opts)
252f3af
     chr->opaque = s;
252f3af
     chr->chr_write = spice_chr_write;
252f3af
     chr->chr_close = spice_chr_close;
252f3af
+    chr->chr_guest_open = spice_chr_guest_open;
252f3af
+    chr->chr_guest_close = spice_chr_guest_close;
252f3af
     s->unblock_timer = qemu_new_timer(vm_clock, spice_chr_unblock, s);
252f3af
 
252f3af
     qemu_chr_generic_open(chr);
252f3af
-- 
252f3af
1.7.3.2
252f3af