diff options
author | Paolo Bonzini <pbonzini@redhat.com> | 2016-09-22 16:09:08 +0200 |
---|---|---|
committer | Paolo Bonzini <pbonzini@redhat.com> | 2016-10-24 15:27:19 +0200 |
commit | adaad61c3c8efb5b4f21ad70c6e141215fdbb304 (patch) | |
tree | c441e4e316d770ecd7fc1b8ba24f015debb52b55 | |
parent | 9a54635dcb51a3fcf7507af630168f514a8cd4e7 (diff) | |
download | qemu-adaad61c3c8efb5b4f21ad70c6e141215fdbb304.zip |
memory: optimize memory_global_dirty_log_sync
Only return a nonzero dirty_log_mask for RAM/ROM memory regions.
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
-rw-r--r-- | memory.c | 8 |
1 files changed, 5 insertions, 3 deletions
@@ -1499,7 +1499,7 @@ bool memory_region_is_skip_dump(MemoryRegion *mr) uint8_t memory_region_get_dirty_log_mask(MemoryRegion *mr) { uint8_t mask = mr->dirty_log_mask; - if (global_dirty_log) { + if (global_dirty_log && mr->ram_block) { mask |= (1 << DIRTY_MEMORY_MIGRATION); } return mask; @@ -2171,8 +2171,10 @@ void memory_global_dirty_log_sync(void) as = listener->address_space; view = address_space_get_flatview(as); FOR_EACH_FLAT_RANGE(fr, view) { - MemoryRegionSection mrs = section_from_flat_range(fr, as); - listener->log_sync(listener, &mrs); + if (fr->dirty_log_mask) { + MemoryRegionSection mrs = section_from_flat_range(fr, as); + listener->log_sync(listener, &mrs); + } } flatview_unref(view); } |