From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mailman by lists.gnu.org with tmda-scanned (Exim 4.43) id 1NFA2i-0003q6-Ow for qemu-devel@nongnu.org; Mon, 30 Nov 2009 12:28:08 -0500 Received: from exim by lists.gnu.org with spam-scanned (Exim 4.43) id 1NFA2a-0003j9-R8 for qemu-devel@nongnu.org; Mon, 30 Nov 2009 12:28:05 -0500 Received: from [199.232.76.173] (port=36090 helo=monty-python.gnu.org) by lists.gnu.org with esmtp (Exim 4.43) id 1NFA2Y-0003if-Fp for qemu-devel@nongnu.org; Mon, 30 Nov 2009 12:27:58 -0500 Received: from goliath.siemens.de ([192.35.17.28]:16749) by monty-python.gnu.org with esmtps (TLS-1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.60) (envelope-from ) id 1NFA2X-0004gC-AY for qemu-devel@nongnu.org; Mon, 30 Nov 2009 12:27:57 -0500 Resent-To: Anthony Liguori Resent-Message-Id: <4B140096.6030803@siemens.com> From: Jan Kiszka Date: Mon, 30 Nov 2009 18:21:21 +0100 Message-ID: <20091130172121.22889.19699.stgit@mchn012c.ww002.siemens.net> In-Reply-To: <20091130172119.22889.28114.stgit@mchn012c.ww002.siemens.net> References: <20091130172119.22889.28114.stgit@mchn012c.ww002.siemens.net> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Subject: [Qemu-devel] [PATCH 16/23] ram migration: Stop loading on error List-Id: qemu-devel.nongnu.org List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Anthony Liguori Cc: qemu-devel@nongnu.org, Liran Schour , Pierre Riteau Besides catching real errors, this also allows to interrrupt the qemu process during restore. Signed-off-by: Jan Kiszka --- vl.c | 6 +++++- 1 files changed, 5 insertions(+), 1 deletions(-) diff --git a/vl.c b/vl.c index ee43808..64426aa 100644 --- a/vl.c +++ b/vl.c @@ -3017,8 +3017,12 @@ static int ram_load(QEMUFile *f, void *opaque, int version_id) madvise(qemu_get_ram_ptr(addr), TARGET_PAGE_SIZE, MADV_DONTNEED); } #endif - } else if (flags & RAM_SAVE_FLAG_PAGE) + } else if (flags & RAM_SAVE_FLAG_PAGE) { qemu_get_buffer(f, qemu_get_ram_ptr(addr), TARGET_PAGE_SIZE); + } + if (qemu_file_has_error(f)) { + return -EIO; + } } while (!(flags & RAM_SAVE_FLAG_EOS)); return 0;