From: Paolo Bonzini Date: Tue, 20 Nov 2012 11:48:19 +0000 (+0100) Subject: buffered_file: do not send more than s->bytes_xfer bytes per tick X-Git-Tag: qemu-xen-4.3.0~6^2~14 X-Git-Url: http://xenbits.xensource.com/gitweb?a=commitdiff_plain;h=ff0c079c1425b004019ab33f4ba1339d9ea365d2;p=qemu-upstream-4.3-testing.git buffered_file: do not send more than s->bytes_xfer bytes per tick Sending more was possible if the buffer was large. Cc: qemu-stable@nongnu.org Signed-off-by: Paolo Bonzini Signed-off-by: Juan Quintela (cherry picked from commit bde54c08b4854aceee3dee25121a2b835cb81166) Signed-off-by: Michael Roth --- diff --git a/buffered_file.c b/buffered_file.c index bd0f61d8c..9a8bd0446 100644 --- a/buffered_file.c +++ b/buffered_file.c @@ -66,9 +66,9 @@ static ssize_t buffered_flush(QEMUFileBuffered *s) DPRINTF("flushing %zu byte(s) of data\n", s->buffer_size); while (s->bytes_xfer < s->xfer_limit && offset < s->buffer_size) { - + size_t to_send = MIN(s->buffer_size - offset, s->xfer_limit - s->bytes_xfer); ret = migrate_fd_put_buffer(s->migration_state, s->buffer + offset, - s->buffer_size - offset); + to_send); if (ret == -EAGAIN) { DPRINTF("backend not ready, freezing\n"); ret = 0;