aboutsummaryrefslogtreecommitdiff
path: root/exec.c
diff options
context:
space:
mode:
authorbellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162>2005-10-30 20:48:42 +0000
committerbellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162>2005-10-30 20:48:42 +0000
commitaab33094073678d459ccaac5c60ea7533e8d1d8e (patch)
treeebd6aa5359709496091f7a092beee2ad06aa0fcb /exec.c
parent05f3fb8de34098a1ff08c30e8a3d575c6f6f2cae (diff)
downloadqemu-aab33094073678d459ccaac5c60ea7533e8d1d8e.zip
qemu-aab33094073678d459ccaac5c60ea7533e8d1d8e.tar.gz
qemu-aab33094073678d459ccaac5c60ea7533e8d1d8e.tar.bz2
more physical memory access functions
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@1587 c046a42c-6fe2-441c-8c8c-71466251a162
Diffstat (limited to 'exec.c')
-rw-r--r--exec.c45
1 files changed, 45 insertions, 0 deletions
diff --git a/exec.c b/exec.c
index 11a3a64..95fbe12 100644
--- a/exec.c
+++ b/exec.c
@@ -2284,6 +2284,30 @@ uint32_t ldl_phys(target_phys_addr_t addr)
return val;
}
+/* XXX: optimize */
+uint32_t ldub_phys(target_phys_addr_t addr)
+{
+ uint8_t val;
+ cpu_physical_memory_read(addr, &val, 1);
+ return val;
+}
+
+/* XXX: optimize */
+uint32_t lduw_phys(target_phys_addr_t addr)
+{
+ uint16_t val;
+ cpu_physical_memory_read(addr, (uint8_t *)&val, 2);
+ return tswap16(val);
+}
+
+/* XXX: optimize */
+uint64_t ldq_phys(target_phys_addr_t addr)
+{
+ uint64_t val;
+ cpu_physical_memory_read(addr, (uint8_t *)&val, 8);
+ return tswap64(val);
+}
+
/* warning: addr must be aligned. The ram page is not masked as dirty
and the code inside is not invalidated. It is useful if the dirty
bits are used to track modified PTEs */
@@ -2345,6 +2369,27 @@ void stl_phys(target_phys_addr_t addr, uint32_t val)
}
}
+/* XXX: optimize */
+void stb_phys(target_phys_addr_t addr, uint32_t val)
+{
+ uint8_t v = val;
+ cpu_physical_memory_write(addr, &v, 1);
+}
+
+/* XXX: optimize */
+void stw_phys(target_phys_addr_t addr, uint32_t val)
+{
+ uint16_t v = tswap16(val);
+ cpu_physical_memory_write(addr, (const uint8_t *)&v, 2);
+}
+
+/* XXX: optimize */
+void stq_phys(target_phys_addr_t addr, uint64_t val)
+{
+ val = tswap64(val);
+ cpu_physical_memory_write(addr, (const uint8_t *)&val, 8);
+}
+
#endif
/* virtual memory access for debug */