904b1d4
From c6c94b043e8b3593d0beb52966dce43069233840 Mon Sep 17 00:00:00 2001
fc7c34c
From: Izik Eidus <ieidus@redhat.com>
fc7c34c
Date: Tue, 28 Jul 2009 19:14:26 +0300
fc7c34c
Subject: [PATCH] kvm userspace: ksm support
fc7c34c
fc7c34c
rfc for ksm support to kvm userpsace.
fc7c34c
fc7c34c
Signed-off-by: Izik Eidus <ieidus@redhat.com>
ef961da
signed-off-by: Justin M. Forbes <jforbes@redhat.com>
fc7c34c
Signed-off-by: Mark McLoughlin <markmc@redhat.com>
fc7c34c
Fedora-patch: qemu-add-ksm-support.patch
fc7c34c
---
ef961da
 exec.c |    6 ++++++
ef961da
 1 files changed, 6 insertions(+), 0 deletions(-)
fc7c34c
fc7c34c
diff --git a/exec.c b/exec.c
ef961da
index 0655b4b..a0e2203 100644
fc7c34c
--- a/exec.c
fc7c34c
+++ b/exec.c
ef961da
@@ -65,6 +65,9 @@
ef961da
 #undef DEBUG_TB_CHECK
ef961da
 #endif
ef961da
 
ef961da
+/* Quick hack to enable KSM support */
ef961da
+#define MADV_MERGEABLE 12 /* KSM may merge identical pages */
ef961da
+
ef961da
 #define SMC_BITMAP_USE_THRESHOLD 10
ef961da
 
ef961da
 #if defined(TARGET_SPARC64)
ef961da
@@ -2579,6 +2582,9 @@ ram_addr_t qemu_ram_alloc(ram_addr_t size)
fc7c34c
     new_block->host = file_ram_alloc(size, mem_path);
fc7c34c
     if (!new_block->host) {
fc7c34c
         new_block->host = qemu_vmalloc(size);
fc7c34c
+#ifdef MADV_MERGEABLE
fc7c34c
+        madvise(new_block->host, size, MADV_MERGEABLE);
fc7c34c
+#endif
fc7c34c
     }
fc7c34c
     new_block->offset = last_ram_offset;
fc7c34c
     new_block->length = size;
fc7c34c
-- 
fc7c34c
1.6.2.5
fc7c34c