mirror of
https://github.com/xemu-project/xemu.git
synced 2024-11-23 19:49:43 +00:00
memory: API to allocate resizeable RAM MR
Add API to allocate resizeable RAM MR. This looks just like regular RAM generally, but has a special property that only a portion of it (used_length) is actually used, and migrated. This used_length size can change across reboots. Follow up patches will change used_length for such blocks at migration, making it easier to extend devices using such RAM (notably ACPI, but in the future thinkably other ROMs) without breaking migration compatibility or wasting ROM (guest) memory. Device is notified on resize, so it can adjust if necessary. Note: nothing prevents making all RAM resizeable in this way. However, reviewers felt that only enabling this selectively will make some class of errors easier to detect. Signed-off-by: Michael S. Tsirkin <mst@redhat.com> Reviewed-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
b0cc3f8397
commit
60786ef339
@ -321,6 +321,30 @@ void memory_region_init_ram(MemoryRegion *mr,
|
|||||||
uint64_t size,
|
uint64_t size,
|
||||||
Error **errp);
|
Error **errp);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* memory_region_init_resizeable_ram: Initialize memory region with resizeable
|
||||||
|
* RAM. Accesses into the region will
|
||||||
|
* modify memory directly. Only an initial
|
||||||
|
* portion of this RAM is actually used.
|
||||||
|
* The used size can change across reboots.
|
||||||
|
*
|
||||||
|
* @mr: the #MemoryRegion to be initialized.
|
||||||
|
* @owner: the object that tracks the region's reference count
|
||||||
|
* @name: the name of the region.
|
||||||
|
* @size: used size of the region.
|
||||||
|
* @max_size: max size of the region.
|
||||||
|
* @resized: callback to notify owner about used size change.
|
||||||
|
* @errp: pointer to Error*, to store an error if it happens.
|
||||||
|
*/
|
||||||
|
void memory_region_init_resizeable_ram(MemoryRegion *mr,
|
||||||
|
struct Object *owner,
|
||||||
|
const char *name,
|
||||||
|
uint64_t size,
|
||||||
|
uint64_t max_size,
|
||||||
|
void (*resized)(const char*,
|
||||||
|
uint64_t length,
|
||||||
|
void *host),
|
||||||
|
Error **errp);
|
||||||
#ifdef __linux__
|
#ifdef __linux__
|
||||||
/**
|
/**
|
||||||
* memory_region_init_ram_from_file: Initialize RAM memory region with a
|
* memory_region_init_ram_from_file: Initialize RAM memory region with a
|
||||||
|
17
memory.c
17
memory.c
@ -1152,6 +1152,23 @@ void memory_region_init_ram(MemoryRegion *mr,
|
|||||||
mr->ram_addr = qemu_ram_alloc(size, mr, errp);
|
mr->ram_addr = qemu_ram_alloc(size, mr, errp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void memory_region_init_resizeable_ram(MemoryRegion *mr,
|
||||||
|
Object *owner,
|
||||||
|
const char *name,
|
||||||
|
uint64_t size,
|
||||||
|
uint64_t max_size,
|
||||||
|
void (*resized)(const char*,
|
||||||
|
uint64_t length,
|
||||||
|
void *host),
|
||||||
|
Error **errp)
|
||||||
|
{
|
||||||
|
memory_region_init(mr, owner, name, size);
|
||||||
|
mr->ram = true;
|
||||||
|
mr->terminates = true;
|
||||||
|
mr->destructor = memory_region_destructor_ram;
|
||||||
|
mr->ram_addr = qemu_ram_alloc_resizeable(size, max_size, resized, mr, errp);
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef __linux__
|
#ifdef __linux__
|
||||||
void memory_region_init_ram_from_file(MemoryRegion *mr,
|
void memory_region_init_ram_from_file(MemoryRegion *mr,
|
||||||
struct Object *owner,
|
struct Object *owner,
|
||||||
|
Loading…
Reference in New Issue
Block a user