aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBlue Swirl <blauwirbel@gmail.com>2012-01-22 11:00:44 +0000
committerBlue Swirl <blauwirbel@gmail.com>2012-01-25 18:32:39 +0000
commit59abb06198ee9471e29c970f294eae80c0b39be1 (patch)
treeb826244ff49f7be0166588390285a01643af58fc
parentc5bd4f3d2ddf243565d94a5a16eafcb994c1524a (diff)
downloadqemu-59abb06198ee9471e29c970f294eae80c0b39be1.zip
qemu-59abb06198ee9471e29c970f294eae80c0b39be1.tar.gz
qemu-59abb06198ee9471e29c970f294eae80c0b39be1.tar.bz2
memory: fix dirty mask function length handling
Fix handling of cases like start = 0xfff, length = 2. Change length to ram_addr_t to handle larger lengths. Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
-rw-r--r--exec-obsolete.h11
1 files changed, 6 insertions, 5 deletions
diff --git a/exec-obsolete.h b/exec-obsolete.h
index c412be9..22e0ba5 100644
--- a/exec-obsolete.h
+++ b/exec-obsolete.h
@@ -77,17 +77,18 @@ static inline int cpu_physical_memory_set_dirty_flags(ram_addr_t addr,
}
static inline void cpu_physical_memory_mask_dirty_range(ram_addr_t start,
- int length,
+ ram_addr_t length,
int dirty_flags)
{
- int i, mask, len;
+ int mask;
uint8_t *p;
+ ram_addr_t addr, end;
- len = length >> TARGET_PAGE_BITS;
+ end = start + length;
mask = ~dirty_flags;
p = ram_list.phys_dirty + (start >> TARGET_PAGE_BITS);
- for (i = 0; i < len; i++) {
- p[i] &= mask;
+ for (addr = start; addr <= end; addr += TARGET_PAGE_SIZE) {
+ *p++ &= mask;
}
}