aboutsummaryrefslogtreecommitdiff
path: root/exec.c
diff options
context:
space:
mode:
authorWen Congyang <wency@cn.fujitsu.com>2012-05-07 12:04:18 +0800
committerLuiz Capitulino <lcapitulino@redhat.com>2012-06-04 13:49:33 -0300
commit76f3553883b868e99c78212b9d12309e8e1e5d81 (patch)
treee81a0ec3f73febd84c827357366dbe3b616df005 /exec.c
parent80167a8a31d7c42e3e33ec23592eb14938c88098 (diff)
downloadqemu-76f3553883b868e99c78212b9d12309e8e1e5d81.zip
qemu-76f3553883b868e99c78212b9d12309e8e1e5d81.tar.gz
qemu-76f3553883b868e99c78212b9d12309e8e1e5d81.tar.bz2
Add API to check whether a physical address is I/O address
This API will be used in the following patch. Signed-off-by: Wen Congyang <wency@cn.fujitsu.com> Signed-off-by: Luiz Capitulino <lcapitulino@redhat.com>
Diffstat (limited to 'exec.c')
-rw-r--r--exec.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/exec.c b/exec.c
index a0494c7..1b65859 100644
--- a/exec.c
+++ b/exec.c
@@ -4336,3 +4336,15 @@ bool virtio_is_big_endian(void)
}
#endif
+
+#ifndef CONFIG_USER_ONLY
+bool cpu_physical_memory_is_io(target_phys_addr_t phys_addr)
+{
+ MemoryRegionSection *section;
+
+ section = phys_page_find(phys_addr >> TARGET_PAGE_BITS);
+
+ return !(memory_region_is_ram(section->mr) ||
+ memory_region_is_romd(section->mr));
+}
+#endif