diff options
author | Alexey Kardashevskiy <aik@ozlabs.ru> | 2014-05-07 13:40:39 +0000 |
---|---|---|
committer | Stefano Stabellini <stefano.stabellini@eu.citrix.com> | 2014-05-07 16:14:36 +0000 |
commit | fe680d0dac85e0f2d6c3b53838c250f6e0b1f49b (patch) | |
tree | 43ab4eec93ccf476c53edb0e6cbf043a3f91cb4c | |
parent | 8d1dc5d188b84a2b2aeb9bd39fddb3d2c67be60c (diff) | |
download | qemu-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.c | 2 |
1 files changed, 1 insertions, 1 deletions
@@ -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); } |