mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-04 08:13:54 -06:00
s390x/s390-virtio-ccw: move setting the maximum guest size from sclp to machine code
Nowadays, it feels more natural to have that code located in s390_memory_init(), where we also have direct access to the machine object. While at it, use the actual RAM size, not the maximum RAM size which cannot currently be reached without support for any memory devices. Consequently update s390_pv_vm_try_disable_async() to rely on the RAM size as well, to avoid temporary issues while we further rework that handling. set_memory_limit() is temporary, we'll merge it with s390_set_memory_limit() next. Message-ID: <20241219144115.2820241-6-david@redhat.com> Acked-by: Michael S. Tsirkin <mst@redhat.com> Reviewed-by: Thomas Huth <thuth@redhat.com> Signed-off-by: David Hildenbrand <david@redhat.com>
This commit is contained in:
parent
85489fc365
commit
3c6fb557d2
3 changed files with 25 additions and 16 deletions
|
@ -376,10 +376,7 @@ void sclp_service_interrupt(uint32_t sccb)
|
|||
/* qemu object creation and initialization functions */
|
||||
static void sclp_realize(DeviceState *dev, Error **errp)
|
||||
{
|
||||
MachineState *machine = MACHINE(qdev_get_machine());
|
||||
SCLPDevice *sclp = SCLP(dev);
|
||||
uint64_t hw_limit;
|
||||
int ret;
|
||||
|
||||
/*
|
||||
* qdev_device_add searches the sysbus for TYPE_SCLP_EVENTS_BUS. As long
|
||||
|
@ -389,14 +386,6 @@ static void sclp_realize(DeviceState *dev, Error **errp)
|
|||
if (!sysbus_realize(SYS_BUS_DEVICE(sclp->event_facility), errp)) {
|
||||
return;
|
||||
}
|
||||
|
||||
ret = s390_set_memory_limit(machine->maxram_size, &hw_limit);
|
||||
if (ret == -E2BIG) {
|
||||
error_setg(errp, "host supports a maximum of %" PRIu64 " GB",
|
||||
hw_limit / GiB);
|
||||
} else if (ret) {
|
||||
error_setg(errp, "setting the guest size failed");
|
||||
}
|
||||
}
|
||||
|
||||
static void sclp_memory_init(SCLPDevice *sclp)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue