|
@@ -93,9 +93,10 @@ static void memory_device_check_addable(MachineState *ms, uint64_t size,
|
|
|
|
|
|
}
|
|
|
|
|
|
-uint64_t memory_device_get_free_addr(MachineState *ms, const uint64_t *hint,
|
|
|
- uint64_t align, uint64_t size,
|
|
|
- Error **errp)
|
|
|
+static uint64_t memory_device_get_free_addr(MachineState *ms,
|
|
|
+ const uint64_t *hint,
|
|
|
+ uint64_t align, uint64_t size,
|
|
|
+ Error **errp)
|
|
|
{
|
|
|
uint64_t address_space_start, address_space_end;
|
|
|
GSList *list = NULL, *item;
|
|
@@ -247,6 +248,31 @@ uint64_t get_plugged_memory_size(void)
|
|
|
return size;
|
|
|
}
|
|
|
|
|
|
+void memory_device_pre_plug(MemoryDeviceState *md, MachineState *ms,
|
|
|
+ const uint64_t *legacy_align, Error **errp)
|
|
|
+{
|
|
|
+ const MemoryDeviceClass *mdc = MEMORY_DEVICE_GET_CLASS(md);
|
|
|
+ Error *local_err = NULL;
|
|
|
+ uint64_t addr, align;
|
|
|
+ MemoryRegion *mr;
|
|
|
+
|
|
|
+ mr = mdc->get_memory_region(md, &local_err);
|
|
|
+ if (local_err) {
|
|
|
+ goto out;
|
|
|
+ }
|
|
|
+
|
|
|
+ align = legacy_align ? *legacy_align : memory_region_get_alignment(mr);
|
|
|
+ addr = mdc->get_addr(md);
|
|
|
+ addr = memory_device_get_free_addr(ms, !addr ? NULL : &addr, align,
|
|
|
+ memory_region_size(mr), &local_err);
|
|
|
+ if (local_err) {
|
|
|
+ goto out;
|
|
|
+ }
|
|
|
+ mdc->set_addr(md, addr, &local_err);
|
|
|
+out:
|
|
|
+ error_propagate(errp, local_err);
|
|
|
+}
|
|
|
+
|
|
|
void memory_device_plug_region(MachineState *ms, MemoryRegion *mr,
|
|
|
uint64_t addr)
|
|
|
{
|