diff options
| author | Luiz Capitulino | 2012-10-05 21:47:57 +0200 |
|---|---|---|
| committer | Anthony Liguori | 2012-10-22 20:26:34 +0200 |
| commit | ad0b5321f1f797274603ebbe20108b0750baee94 (patch) | |
| tree | d66e04150cabc509f915b1ac7b13de163457816f | |
| parent | Merge remote-tracking branch 'quintela/migration-next-20121017' into staging (diff) | |
| download | qemu-ad0b5321f1f797274603ebbe20108b0750baee94.tar.gz qemu-ad0b5321f1f797274603ebbe20108b0750baee94.tar.xz qemu-ad0b5321f1f797274603ebbe20108b0750baee94.zip | |
Call MADV_HUGEPAGE for guest RAM allocations
This makes it possible for QEMU to use transparent huge pages (THP)
when transparent_hugepage/enabled=madvise. Otherwise THP is only
used when it's enabled system wide.
Signed-off-by: Luiz Capitulino <lcapitulino@redhat.com>
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
| -rw-r--r-- | exec.c | 1 | ||||
| -rw-r--r-- | osdep.h | 5 |
2 files changed, 6 insertions, 0 deletions
@@ -2571,6 +2571,7 @@ ram_addr_t qemu_ram_alloc_from_ptr(ram_addr_t size, void *host, cpu_physical_memory_set_dirty_range(new_block->offset, size, 0xff); qemu_ram_setup_dump(new_block->host, size); + qemu_madvise(new_block->host, size, QEMU_MADV_HUGEPAGE); if (kvm_enabled()) kvm_setup_guest_memory(new_block->host, size); @@ -108,6 +108,11 @@ void qemu_vfree(void *ptr); #else #define QEMU_MADV_DONTDUMP QEMU_MADV_INVALID #endif +#ifdef MADV_HUGEPAGE +#define QEMU_MADV_HUGEPAGE MADV_HUGEPAGE +#else +#define QEMU_MADV_HUGEPAGE QEMU_MADV_INVALID +#endif #elif defined(CONFIG_POSIX_MADVISE) |
