diff options
author | Gerd Hoffmann <kraxel@redhat.com> | 2013-06-24 08:39:54 +0200 |
---|---|---|
committer | Michael Tokarev <mjt@tls.msk.ru> | 2013-06-28 22:10:34 +0400 |
commit | bb6fb7c0857aeda7982ac14460328edf3c29cfc8 (patch) | |
tree | 500c35b059936f1522416e82343deae0698ee7e6 | |
parent | dc2c4eca89ec5ee7b7a4c2563c991a14a7c5ee84 (diff) | |
download | qemu-bb6fb7c0857aeda7982ac14460328edf3c29cfc8.zip qemu-bb6fb7c0857aeda7982ac14460328edf3c29cfc8.tar.gz qemu-bb6fb7c0857aeda7982ac14460328edf3c29cfc8.tar.bz2 |
qemu-char: add -chardev mux support
Allow to explicitly create mux chardevs on the command line,
like you can using QMP.
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
Reviewed-by: Laszlo Ersek <lersek@redhat.com>
Signed-off-by: Michael Tokarev <mjt@tls.msk.ru>
-rw-r--r-- | qemu-char.c | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/qemu-char.c b/qemu-char.c index 392de29..c097ca1 100644 --- a/qemu-char.c +++ b/qemu-char.c @@ -3115,6 +3115,19 @@ static void qemu_chr_parse_memory(QemuOpts *opts, ChardevBackend *backend, } } +static void qemu_chr_parse_mux(QemuOpts *opts, ChardevBackend *backend, + Error **errp) +{ + const char *chardev = qemu_opt_get(opts, "chardev"); + + if (chardev == NULL) { + error_setg(errp, "chardev: mux: no chardev given"); + return; + } + backend->mux = g_new0(ChardevMux, 1); + backend->mux->chardev = g_strdup(chardev); +} + typedef struct CharDriver { const char *name; /* old, pre qapi */ @@ -3481,6 +3494,9 @@ QemuOptsList qemu_chardev_opts = { },{ .name = "size", .type = QEMU_OPT_SIZE, + },{ + .name = "chardev", + .type = QEMU_OPT_STRING, }, { /* end of list */ } }, @@ -3771,6 +3787,8 @@ static void register_types(void) register_char_driver_qapi("console", CHARDEV_BACKEND_KIND_CONSOLE, NULL); register_char_driver_qapi("pipe", CHARDEV_BACKEND_KIND_PIPE, qemu_chr_parse_pipe); + register_char_driver_qapi("mux", CHARDEV_BACKEND_KIND_MUX, + qemu_chr_parse_mux); } type_init(register_types); |