mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-07 17:53:56 -06:00
numa: Teach ram block notifiers about resizeable ram blocks
Ram block notifiers are currently not aware of resizes. To properly handle resizes during migration, we want to teach ram block notifiers about resizeable ram. Introduce the basic infrastructure but keep using max_size in the existing notifiers. Supply the max_size when adding and removing ram blocks. Also, notify on resizes. Acked-by: Paul Durrant <paul@xen.org> Reviewed-by: Peter Xu <peterx@redhat.com> Cc: xen-devel@lists.xenproject.org Cc: haxm-team@intel.com Cc: Paul Durrant <paul@xen.org> Cc: Stefano Stabellini <sstabellini@kernel.org> Cc: Anthony Perard <anthony.perard@citrix.com> Cc: Wenchao Wang <wenchao.wang@intel.com> Cc: Colin Xu <colin.xu@intel.com> Signed-off-by: David Hildenbrand <david@redhat.com> Message-Id: <20210429112708.12291-3-david@redhat.com> Signed-off-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
This commit is contained in:
parent
082851a3af
commit
8f44304c76
7 changed files with 61 additions and 32 deletions
|
@ -169,7 +169,8 @@ static void xen_remap_bucket(MapCacheEntry *entry,
|
|||
|
||||
if (entry->vaddr_base != NULL) {
|
||||
if (!(entry->flags & XEN_MAPCACHE_ENTRY_DUMMY)) {
|
||||
ram_block_notify_remove(entry->vaddr_base, entry->size);
|
||||
ram_block_notify_remove(entry->vaddr_base, entry->size,
|
||||
entry->size);
|
||||
}
|
||||
|
||||
/*
|
||||
|
@ -224,7 +225,7 @@ static void xen_remap_bucket(MapCacheEntry *entry,
|
|||
}
|
||||
|
||||
if (!(entry->flags & XEN_MAPCACHE_ENTRY_DUMMY)) {
|
||||
ram_block_notify_add(vaddr_base, size);
|
||||
ram_block_notify_add(vaddr_base, size, size);
|
||||
}
|
||||
|
||||
entry->vaddr_base = vaddr_base;
|
||||
|
@ -465,7 +466,7 @@ static void xen_invalidate_map_cache_entry_unlocked(uint8_t *buffer)
|
|||
}
|
||||
|
||||
pentry->next = entry->next;
|
||||
ram_block_notify_remove(entry->vaddr_base, entry->size);
|
||||
ram_block_notify_remove(entry->vaddr_base, entry->size, entry->size);
|
||||
if (munmap(entry->vaddr_base, entry->size) != 0) {
|
||||
perror("unmap fails");
|
||||
exit(-1);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue