From 30868442a5590991266a34af3f0b728a4a0ee6d0 Mon Sep 17 00:00:00 2001 From: Anthony Liguori Date: Wed, 17 Jun 2009 16:46:12 -0500 Subject: [PATCH] Instead of writing a zero page, madvise it away Otherwise, after migration, we end up with a much larger RSS size then we ought to have. Signed-off-by: Anthony Liguori --- vl.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/vl.c b/vl.c index 2d9f04e4c2..ca26450e30 100644 --- a/vl.c +++ b/vl.c @@ -3346,6 +3346,12 @@ static int ram_load(QEMUFile *f, void *opaque, int version_id) if (flags & RAM_SAVE_FLAG_COMPRESS) { uint8_t ch = qemu_get_byte(f); +#if defined(__linux__) + if (ch == 0 && + (!kvm_enabled() || kvm_has_sync_mmu())) { + madvise(qemu_get_ram_ptr(addr), TARGET_PAGE_SIZE, MADV_DONTNEED); + } else +#endif memset(qemu_get_ram_ptr(addr), ch, TARGET_PAGE_SIZE); } else if (flags & RAM_SAVE_FLAG_PAGE) qemu_get_buffer(f, qemu_get_ram_ptr(addr), TARGET_PAGE_SIZE);