aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlexey Kardashevskiy <aik@ozlabs.ru>2014-05-07 13:40:39 +0000
committerStefano Stabellini <stefano.stabellini@eu.citrix.com>2014-05-07 16:14:36 +0000
commitfe680d0dac85e0f2d6c3b53838c250f6e0b1f49b (patch)
tree43ab4eec93ccf476c53edb0e6cbf043a3f91cb4c
parent8d1dc5d188b84a2b2aeb9bd39fddb3d2c67be60c (diff)
downloadqemu-fe680d0dac85e0f2d6c3b53838c250f6e0b1f49b.zip
qemu-fe680d0dac85e0f2d6c3b53838c250f6e0b1f49b.tar.gz
qemu-fe680d0dac85e0f2d6c3b53838c250f6e0b1f49b.tar.bz2
exec: Limit translation limiting in address_space_translate to xen
The address_space_translate() function cuts the returned plen (page size) to hardcoded TARGET_PAGE_SIZE. This function can be used on pages bigger than that so this limiting should not be used on such pages. Since originally the limiting was introduced for XEN, we can safely limit this piece of code to XEN. So does the patch. Suggested-by: Paolo Bonzini <pbonzini@redhat.com> Signed-off-by: Alexey Kardashevskiy <aik@ozlabs.ru> Signed-off-by: Stefano Stabellini <stefano.stabellini@eu.citrix.com>
-rw-r--r--exec.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/exec.c b/exec.c
index 91513c6..cf12049 100644
--- a/exec.c
+++ b/exec.c
@@ -380,7 +380,7 @@ MemoryRegion *address_space_translate(AddressSpace *as, hwaddr addr,
as = iotlb.target_as;
}
- if (memory_access_is_direct(mr, is_write)) {
+ if (xen_enabled() && memory_access_is_direct(mr, is_write)) {
hwaddr page = ((addr & TARGET_PAGE_MASK) + TARGET_PAGE_SIZE) - addr;
len = MIN(page, len);
}