[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH 1/6] chardev: Allow frontends to notify backends of
From: |
Amit Shah |
Subject: |
[Qemu-devel] [PATCH 1/6] chardev: Allow frontends to notify backends of guest open / close |
Date: |
Thu, 28 Apr 2011 13:00:48 +0530 |
From: Hans de Goede <address@hidden>
Some frontends know when the guest has opened the "channel" and is actively
listening to it, for example virtio-serial. This patch adds 2 new qemu-chardev
functions which can be used by frontends to signal guest open / close, and
allows interested backends to listen to this.
Signed-off-by: Hans de Goede <address@hidden>
Reviewed-by: Alon Levy <address@hidden>
Signed-off-by: Amit Shah <address@hidden>
---
qemu-char.c | 17 +++++++++++++++++
qemu-char.h | 4 ++++
2 files changed, 21 insertions(+), 0 deletions(-)
diff --git a/qemu-char.c b/qemu-char.c
index 03858d4..710d98f 100644
--- a/qemu-char.c
+++ b/qemu-char.c
@@ -480,6 +480,9 @@ static CharDriverState *qemu_chr_open_mux(CharDriverState
*drv)
chr->chr_write = mux_chr_write;
chr->chr_update_read_handler = mux_chr_update_read_handler;
chr->chr_accept_input = mux_chr_accept_input;
+ /* Frontend guest-open / -close notification is not support with muxes */
+ chr->chr_guest_open = NULL;
+ chr->chr_guest_close = NULL;
/* Muxes are always open on creation */
qemu_chr_generic_open(chr);
@@ -2579,6 +2582,20 @@ void qemu_chr_set_echo(struct CharDriverState *chr, bool
echo)
}
}
+void qemu_chr_guest_open(struct CharDriverState *chr)
+{
+ if (chr->chr_guest_open) {
+ chr->chr_guest_open(chr);
+ }
+}
+
+void qemu_chr_guest_close(struct CharDriverState *chr)
+{
+ if (chr->chr_guest_close) {
+ chr->chr_guest_close(chr);
+ }
+}
+
void qemu_chr_close(CharDriverState *chr)
{
QTAILQ_REMOVE(&chardevs, chr, next);
diff --git a/qemu-char.h b/qemu-char.h
index fb96eef..2f8512e 100644
--- a/qemu-char.h
+++ b/qemu-char.h
@@ -65,6 +65,8 @@ struct CharDriverState {
void (*chr_close)(struct CharDriverState *chr);
void (*chr_accept_input)(struct CharDriverState *chr);
void (*chr_set_echo)(struct CharDriverState *chr, bool echo);
+ void (*chr_guest_open)(struct CharDriverState *chr);
+ void (*chr_guest_close)(struct CharDriverState *chr);
void *opaque;
QEMUBH *bh;
char *label;
@@ -79,6 +81,8 @@ CharDriverState *qemu_chr_open_opts(QemuOpts *opts,
void (*init)(struct CharDriverState *s));
CharDriverState *qemu_chr_open(const char *label, const char *filename, void
(*init)(struct CharDriverState *s));
void qemu_chr_set_echo(struct CharDriverState *chr, bool echo);
+void qemu_chr_guest_open(struct CharDriverState *chr);
+void qemu_chr_guest_close(struct CharDriverState *chr);
void qemu_chr_close(CharDriverState *chr);
void qemu_chr_printf(CharDriverState *s, const char *fmt, ...)
GCC_FMT_ATTR(2, 3);
--
1.7.4.4
- [Qemu-devel] [PULL] char, virtio-serial, spice, Amit Shah, 2011/04/28
- [Qemu-devel] [PATCH 3/6] spice-chardev: listen to frontend guest open / close, Amit Shah, 2011/04/28
- [Qemu-devel] [PATCH 1/6] chardev: Allow frontends to notify backends of guest open / close,
Amit Shah <=
- [Qemu-devel] [PATCH 4/6] char: Allow devices to use a single multiplexed chardev., Amit Shah, 2011/04/28
- [Qemu-devel] [PATCH 2/6] virtio-console: notify backend of guest open / close, Amit Shah, 2011/04/28
- [Qemu-devel] [PATCH 5/6] char: Detect chardev release by NULL handlers as well as NULL opaque, Amit Shah, 2011/04/28
- [Qemu-devel] [PATCH 6/6] virtio-serial: Fix endianness bug in the config space, Amit Shah, 2011/04/28
- Re: [Qemu-devel] [PULL] char, virtio-serial, spice, Anthony Liguori, 2011/04/28