From 1d0f0d91f298cbda1990edc92cf8ac306c474cdf Mon Sep 17 00:00:00 2001 From: Paolo Bonzini Date: Tue, 2 Feb 2010 20:33:09 +0100 Subject: do not loop on an incomplete io_thread_fd read No need to loop if less than a full buffer is read, the next read would return EAGAIN. Signed-off-by: Paolo Bonzini Signed-off-by: Anthony Liguori --- vl.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'vl.c') diff --git a/vl.c b/vl.c index b87044c53c..f98661f34e 100644 --- a/vl.c +++ b/vl.c @@ -3229,12 +3229,12 @@ static void qemu_event_read(void *opaque) { int fd = (unsigned long)opaque; ssize_t len; + char buffer[512]; /* Drain the notify pipe */ do { - char buffer[512]; len = read(fd, buffer, sizeof(buffer)); - } while ((len == -1 && errno == EINTR) || len > 0); + } while ((len == -1 && errno == EINTR) || len == sizeof(buffer)); } static int qemu_event_init(void) -- cgit v1.2.3