提交 b232c785 编写于 作者: A Alexey Kardashevskiy 提交者: Paolo Bonzini

kvm-all: Align to qemu_real_host_page_size in kvm_set_phys_mem

As the comment in kvm_set_phys_mem() says, KVM works in page size chunks.
However it uses hardcoded TARGET_PAGE_SIZE which is 4K on most platforms
while actual host may use different page size, for example, PPC64 hosts
use 64K system pages.

This replaces static TARGET_PAGE_SIZE with run-time calculated
qemu_real_host_page_size.
Signed-off-by: NAlexey Kardashevskiy <aik@ozlabs.ru>
Message-Id: <1444102257-17405-1-git-send-email-aik@ozlabs.ru>
Signed-off-by: NPaolo Bonzini <pbonzini@redhat.com>
上级 88401cbc
...@@ -642,15 +642,15 @@ static void kvm_set_phys_mem(KVMMemoryListener *kml, ...@@ -642,15 +642,15 @@ static void kvm_set_phys_mem(KVMMemoryListener *kml,
/* kvm works in page size chunks, but the function may be called /* kvm works in page size chunks, but the function may be called
with sub-page size and unaligned start address. Pad the start with sub-page size and unaligned start address. Pad the start
address to next and truncate size to previous page boundary. */ address to next and truncate size to previous page boundary. */
delta = (TARGET_PAGE_SIZE - (start_addr & ~TARGET_PAGE_MASK)); delta = qemu_real_host_page_size - (start_addr & ~qemu_real_host_page_mask);
delta &= ~TARGET_PAGE_MASK; delta &= ~qemu_real_host_page_mask;
if (delta > size) { if (delta > size) {
return; return;
} }
start_addr += delta; start_addr += delta;
size -= delta; size -= delta;
size &= TARGET_PAGE_MASK; size &= qemu_real_host_page_mask;
if (!size || (start_addr & ~TARGET_PAGE_MASK)) { if (!size || (start_addr & ~qemu_real_host_page_mask)) {
return; return;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册