[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH 10/11] chardev: add socket chardev support to ch
From: |
Eric Blake |
Subject: |
Re: [Qemu-devel] [PATCH 10/11] chardev: add socket chardev support to chardev-add (qmp) |
Date: |
Wed, 09 Jan 2013 13:03:52 -0700 |
User-agent: |
Mozilla/5.0 (X11; Linux x86_64; rv:17.0) Gecko/17.0 Thunderbird/17.0 |
On 01/07/2013 06:55 AM, Gerd Hoffmann wrote:
> qemu_chr_open_socket is splitted into two functions. All initialization
s/splitted/split/
> after creating the socket file handler is splitted away into the new
and again
> qemu_chr_open_socket_fd function.
>
> chr->filename doesn't get filled from QemuOpts any more. Qemu gathers
> the information using getsockname and getnameinfo instead. This way it
> will also work correctly for file handles passed via file descriptor
> passing.
>
> Finally qmp_chardev_open_socket() is the actual qmp hotplug
> implementation which basically just calls socket_listen or
> socket_connect and the new qemu_chr_open_socket_fd function.
>
> Signed-off-by: Gerd Hoffmann <address@hidden>
> ---
> qapi-schema.json | 13 +++-
> qemu-char.c | 168 ++++++++++++++++++++++++++++++++++++-----------------
> 2 files changed, 124 insertions(+), 57 deletions(-)
>
> +++ b/qemu-char.c
> @@ -2438,10 +2438,88 @@ static void tcp_chr_close(CharDriverState *chr)
> qemu_chr_be_event(chr, CHR_EVENT_CLOSED);
> }
>
> -static CharDriverState *qemu_chr_open_socket(QemuOpts *opts)
> +static CharDriverState *qemu_chr_open_socket_fd(int fd, int do_nodelay,
> + int is_listen, int is_telnet,
> + int is_waitconnect,
These three parameters sound like they might be better as 'bool' instead
of 'int'.
> @@ -2458,10 +2536,7 @@ static CharDriverState *qemu_chr_open_socket(QemuOpts
> *opts)
> if (!is_listen)
> is_waitconnect = 0;
>
> - chr = g_malloc0(sizeof(CharDriverState));
> - s = g_malloc0(sizeof(TCPCharDriver));
> -
> - if (is_unix) {
> + if (is_unix) {
Spurious re-indentation?
>
> +static CharDriverState *qmp_chardev_open_socket(ChardevSocket *sock,
> + Error **errp)
> +{
> + SocketAddress *addr = sock->addr;
> + bool do_nodelay = sock->has_delay ? !sock->delay : true;
> + bool is_listen = sock->has_server ? sock->server : true;
> + bool is_telnet = sock->has_telnet ? sock->telnet : false;
> + bool is_waitconnect = sock->has_wait ? sock->wait : false;
Especially since you are using bool here.
--
Eric Blake eblake redhat com +1-919-301-3266
Libvirt virtualization library http://libvirt.org
signature.asc
Description: OpenPGP digital signature
- [Qemu-devel] [PATCH 09/11] chardev: add parport chardev support to chardev-add (qmp), (continued)
- [Qemu-devel] [PATCH 10/11] chardev: add socket chardev support to chardev-add (qmp), Gerd Hoffmann, 2013/01/07
- Re: [Qemu-devel] [PATCH 10/11] chardev: add socket chardev support to chardev-add (qmp),
Eric Blake <=
- [Qemu-devel] [PATCH 07/11] chardev: add tty chardev support to chardev-add (qmp), Gerd Hoffmann, 2013/01/07
- [Qemu-devel] [PATCH 03/11] chardev: reduce chardev ifdef mess a bit, Gerd Hoffmann, 2013/01/07
- [Qemu-devel] [PATCH 11/11] chardev: add pty chardev support to chardev-add (qmp), Gerd Hoffmann, 2013/01/07
- [Qemu-devel] [PATCH 06/11] chardev: add file chardev support to chardev-add (qmp), Gerd Hoffmann, 2013/01/07