aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlex Williamson <alex.williamson@redhat.com>2010-08-19 10:18:42 -0300
committerLuiz Capitulino <lcapitulino@redhat.com>2010-10-11 19:52:37 -0300
commitc082082c7669aa9fba4034484f56583dc2e0eaae (patch)
treed3f4057be2f4f595b1fba9761198c30191a92cda
parentc4127fbf17744374b147b779a333e7bf444839a7 (diff)
downloadqemu-c082082c7669aa9fba4034484f56583dc2e0eaae.zip
qemu-c082082c7669aa9fba4034484f56583dc2e0eaae.tar.gz
qemu-c082082c7669aa9fba4034484f56583dc2e0eaae.tar.bz2
savevm: Reset last block info at beginning of each save
If we save more than once we need to reset the last block info or else only the first save has the actual block info and each subsequent save will only use continue flags, making them unloadable independently. Found-by: Miguel Di Ciurcio Filho <miguel.filho@gmail.com> Signed-off-by: Alex Williamson <alex.williamson@redhat.com> Acked-by: Glauber Costa <glommer@redhat.com> Signed-off-by: Luiz Capitulino <lcapitulino@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com> (cherry picked from commit 760e77eab53f5d92eb0c587e04fd942a905b46af)
-rw-r--r--arch_init.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/arch_init.c b/arch_init.c
index 47bb4b2..e0bd18c 100644
--- a/arch_init.c
+++ b/arch_init.c
@@ -104,10 +104,11 @@ static int is_dup_page(uint8_t *page, uint8_t ch)
return 1;
}
+static RAMBlock *last_block;
+static ram_addr_t last_offset;
+
static int ram_save_block(QEMUFile *f)
{
- static RAMBlock *last_block = NULL;
- static ram_addr_t last_offset = 0;
RAMBlock *block = last_block;
ram_addr_t offset = last_offset;
ram_addr_t current_addr;
@@ -231,6 +232,8 @@ int ram_save_live(Monitor *mon, QEMUFile *f, int stage, void *opaque)
if (stage == 1) {
RAMBlock *block;
bytes_transferred = 0;
+ last_block = NULL;
+ last_offset = 0;
/* Make sure all dirty bits are set */
QLIST_FOREACH(block, &ram_list.blocks, next) {