|
|
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 |
|