diff options
author | Paolo Bonzini <pbonzini@redhat.com> | 2015-07-21 09:25:54 +0200 |
---|---|---|
committer | Paolo Bonzini <pbonzini@redhat.com> | 2015-07-23 07:37:38 +0200 |
commit | 9172f428afc1461b1d9b33ebca3a679b9adf7c3a (patch) | |
tree | cdecd1fe1d7b58b4e4fdac21b5d2c39e6bc816a7 | |
parent | 0b8e2c1002afddc8ef3d52fa6fc29e4768429f98 (diff) | |
download | qemu-9172f428afc1461b1d9b33ebca3a679b9adf7c3a.zip qemu-9172f428afc1461b1d9b33ebca3a679b9adf7c3a.tar.gz qemu-9172f428afc1461b1d9b33ebca3a679b9adf7c3a.tar.bz2 |
qemu-char: handle EINTR for TCP character devices
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
-rw-r--r-- | qemu-char.c | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/qemu-char.c b/qemu-char.c index 617e034..3200200 100644 --- a/qemu-char.c +++ b/qemu-char.c @@ -2797,7 +2797,10 @@ static ssize_t tcp_chr_recv(CharDriverState *chr, char *buf, size_t len) #ifdef MSG_CMSG_CLOEXEC flags |= MSG_CMSG_CLOEXEC; #endif - ret = recvmsg(s->fd, &msg, flags); + do { + ret = recvmsg(s->fd, &msg, flags); + } while (ret == -1 && errno == EINTR); + if (ret > 0 && s->is_unix) { unix_process_msgfd(chr, &msg); } @@ -2808,7 +2811,13 @@ static ssize_t tcp_chr_recv(CharDriverState *chr, char *buf, size_t len) static ssize_t tcp_chr_recv(CharDriverState *chr, char *buf, size_t len) { TCPCharDriver *s = chr->opaque; - return qemu_recv(s->fd, buf, len, 0); + ssize_t ret; + + do { + ret = qemu_recv(s->fd, buf, len, 0); + } while (ret == -1 && socket_error() == EINTR); + + return ret; } #endif |