[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH] chardev: block during sync read
From: |
Paolo Bonzini |
Subject: |
Re: [Qemu-devel] [PATCH] chardev: block during sync read |
Date: |
Fri, 7 Jul 2017 12:57:08 +0200 |
User-agent: |
Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.2.0 |
On 06/07/2017 19:03, Marc-André Lureau wrote:
> A sync read should block until all requested data is
> available (instead of retrying in qemu_chr_fe_read_all). Change the
> channel to blocking during sync_read.
>
> Signed-off-by: Marc-André Lureau <address@hidden>
> ---
> chardev/char-socket.c | 2 ++
> 1 file changed, 2 insertions(+)
>
> diff --git a/chardev/char-socket.c b/chardev/char-socket.c
> index ccc499cfa1..7e6648b03a 100644
> --- a/chardev/char-socket.c
> +++ b/chardev/char-socket.c
> @@ -454,7 +454,9 @@ static int tcp_chr_sync_read(Chardev *chr, const uint8_t
> *buf, int len)
> return 0;
> }
>
> + qio_channel_set_blocking(s->ioc, true, NULL);
> size = tcp_chr_recv(chr, (void *) buf, len);
> + qio_channel_set_blocking(s->ioc, false, NULL);
> if (size == 0) {
> /* connection closed */
> tcp_chr_disconnect(chr);
>
Acked-by: Paolo Bonzini <address@hidden>