From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mailman by lists.gnu.org with tmda-scanned (Exim 4.43) id 1NHyvI-0005f0-S3 for qemu-devel@nongnu.org; Tue, 08 Dec 2009 07:12:09 -0500 Received: from exim by lists.gnu.org with spam-scanned (Exim 4.43) id 1NHyvD-0005cb-9z for qemu-devel@nongnu.org; Tue, 08 Dec 2009 07:12:07 -0500 Received: from [199.232.76.173] (port=44191 helo=monty-python.gnu.org) by lists.gnu.org with esmtp (Exim 4.43) id 1NHyvC-0005cL-Jr for qemu-devel@nongnu.org; Tue, 08 Dec 2009 07:12:02 -0500 Received: from mx1.redhat.com ([209.132.183.28]:53884) by monty-python.gnu.org with esmtp (Exim 4.60) (envelope-from ) id 1NHyvC-00081w-6k for qemu-devel@nongnu.org; Tue, 08 Dec 2009 07:12:02 -0500 From: Gerd Hoffmann Date: Tue, 8 Dec 2009 13:11:36 +0100 Message-Id: <1260274314-2906-5-git-send-email-kraxel@redhat.com> In-Reply-To: <1260274314-2906-1-git-send-email-kraxel@redhat.com> References: <1260274314-2906-1-git-send-email-kraxel@redhat.com> Subject: [Qemu-devel] [FOR 0.12 PATCH v4 04/22] chardev: make chardevs specified in config file work. List-Id: qemu-devel.nongnu.org List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Cc: Gerd Hoffmann , agraf@suse.de, lcapitulino@redhat.com The patch decuples the -chardev switch and the actual chardev initialization. Without this patch qemu ignores chardev entries coming via -readconfig. Signed-off-by: Gerd Hoffmann --- vl.c | 16 +++++++++++++--- 1 files changed, 13 insertions(+), 3 deletions(-) diff --git a/vl.c b/vl.c index f7acdd4..aa678ad 100644 --- a/vl.c +++ b/vl.c @@ -4586,6 +4586,16 @@ static int device_init_func(QemuOpts *opts, void *opaque) return 0; } +static int chardev_init_func(QemuOpts *opts, void *opaque) +{ + CharDriverState *chr; + + chr = qemu_chr_open_opts(opts, NULL); + if (!chr) + return -1; + return 0; +} + struct device_config { enum { DEV_USB, /* -usbdevice */ @@ -5180,9 +5190,6 @@ int main(int argc, char **argv, char **envp) fprintf(stderr, "parse error: %s\n", optarg); exit(1); } - if (qemu_chr_open_opts(opts, NULL) == NULL) { - exit(1); - } break; case QEMU_OPTION_serial: if (serial_device_index >= MAX_SERIAL_PORTS) { @@ -5501,6 +5508,9 @@ int main(int argc, char **argv, char **envp) } } + if (qemu_opts_foreach(&qemu_chardev_opts, chardev_init_func, NULL, 1) != 0) + exit(1); + #ifndef _WIN32 if (daemonize) { pid_t pid; -- 1.6.5.2