|
@@ -74,6 +74,11 @@ static inline int cpu_physical_memory_get_dirty(ram_addr_t start,
|
|
static inline int cpu_physical_memory_set_dirty_flags(ram_addr_t addr,
|
|
static inline int cpu_physical_memory_set_dirty_flags(ram_addr_t addr,
|
|
int dirty_flags)
|
|
int dirty_flags)
|
|
{
|
|
{
|
|
|
|
+ if ((dirty_flags & MIGRATION_DIRTY_FLAG) &&
|
|
|
|
+ !cpu_physical_memory_get_dirty(addr, TARGET_PAGE_SIZE,
|
|
|
|
+ MIGRATION_DIRTY_FLAG)) {
|
|
|
|
+ ram_list.dirty_pages++;
|
|
|
|
+ }
|
|
return ram_list.phys_dirty[addr >> TARGET_PAGE_BITS] |= dirty_flags;
|
|
return ram_list.phys_dirty[addr >> TARGET_PAGE_BITS] |= dirty_flags;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -87,6 +92,11 @@ static inline int cpu_physical_memory_clear_dirty_flags(ram_addr_t addr,
|
|
{
|
|
{
|
|
int mask = ~dirty_flags;
|
|
int mask = ~dirty_flags;
|
|
|
|
|
|
|
|
+ if ((dirty_flags & MIGRATION_DIRTY_FLAG) &&
|
|
|
|
+ cpu_physical_memory_get_dirty(addr, TARGET_PAGE_SIZE,
|
|
|
|
+ MIGRATION_DIRTY_FLAG)) {
|
|
|
|
+ ram_list.dirty_pages--;
|
|
|
|
+ }
|
|
return ram_list.phys_dirty[addr >> TARGET_PAGE_BITS] &= mask;
|
|
return ram_list.phys_dirty[addr >> TARGET_PAGE_BITS] &= mask;
|
|
}
|
|
}
|
|
|
|
|