From: Jan Kiszka Date: Mon, 6 May 2013 14:48:02 +0000 (+0200) Subject: memory: Introduce address_space_lookup_region X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=9f029603abb1472a33e008f9ea4127cc52566986;p=qemu.git memory: Introduce address_space_lookup_region This introduces a wrapper for phys_page_find (before we complicate address_space_translate with IOMMU translation). This function will also encapsulate locking and reference counting when we introduce BQL-free dispatching. Signed-off-by: Jan Kiszka Signed-off-by: Paolo Bonzini --- diff --git a/exec.c b/exec.c index eb200d0ffc..86efed76bc 100644 --- a/exec.c +++ b/exec.c @@ -203,6 +203,12 @@ bool memory_region_is_unassigned(MemoryRegion *mr) && mr != &io_mem_watch; } +static MemoryRegionSection *address_space_lookup_region(AddressSpace *as, + hwaddr addr) +{ + return phys_page_find(as->dispatch, addr >> TARGET_PAGE_BITS); +} + MemoryRegionSection *address_space_translate(AddressSpace *as, hwaddr addr, hwaddr *xlat, hwaddr *plen, bool is_write) @@ -210,7 +216,7 @@ MemoryRegionSection *address_space_translate(AddressSpace *as, hwaddr addr, MemoryRegionSection *section; Int128 diff; - section = phys_page_find(as->dispatch, addr >> TARGET_PAGE_BITS); + section = address_space_lookup_region(as, addr); /* Compute offset within MemoryRegionSection */ addr -= section->offset_within_address_space;