On 14.05.2018 12:00, David Hildenbrand wrote: > Let's route all memory devices we can hotplug through the machine hotplug > handler, just like on pc and spapr. > > As CONFIG_DIMM is not enabled, we won't ever try to plug DIMMs. > > Signed-off-by: David Hildenbrand <da...@redhat.com> > --- > default-configs/s390x-softmmu.mak | 1 + > hw/s390x/s390-virtio-ccw.c | 31 ++++++++++++++++++++++++++++++- > 2 files changed, 31 insertions(+), 1 deletion(-) > > diff --git a/default-configs/s390x-softmmu.mak > b/default-configs/s390x-softmmu.mak > index 2f4bfe73b4..c0628c0123 100644 > --- a/default-configs/s390x-softmmu.mak > +++ b/default-configs/s390x-softmmu.mak > @@ -9,3 +9,4 @@ CONFIG_S390_FLIC=y > CONFIG_S390_FLIC_KVM=$(CONFIG_KVM) > CONFIG_VFIO_CCW=$(CONFIG_LINUX) > CONFIG_WDT_DIAG288=y > +CONFIG_MEM_DEVICE=y > diff --git a/hw/s390x/s390-virtio-ccw.c b/hw/s390x/s390-virtio-ccw.c > index 7700658400..54c620baf2 100644 > --- a/hw/s390x/s390-virtio-ccw.c > +++ b/hw/s390x/s390-virtio-ccw.c > @@ -35,6 +35,7 @@ > #include "migration/register.h" > #include "cpu_models.h" > #include "hw/nmi.h" > +#include "hw/mem/memory-device.h" > > S390CPU *s390_cpu_addr2state(uint16_t cpu_addr) > { > @@ -436,12 +437,29 @@ static void s390_machine_device_plug(HotplugHandler > *hotplug_dev, > { > Error *local_err = NULL; > > + /* first stage hotplug handler */ > + if (object_dynamic_cast(OBJECT(dev), TYPE_MEMORY_DEVICE)) { > + memory_device_plug(MACHINE(hotplug_dev), MEMORY_DEVICE(dev), NULL, > + &local_err); > + } > + > + if (local_err) { > + error_propagate(errp, local_err); > + return; > + } > + > /* final stage hotplug handler */ > if (object_dynamic_cast(OBJECT(dev), TYPE_CPU)) { > s390_cpu_plug(hotplug_dev, dev, &local_err); > } else if (dev->parent_bus && dev->parent_bus->hotplug_handler) { > hotplug_handler_plug(dev->parent_bus->hotplug_handler, dev, > &local_err); > } > + > + if (local_err) { > + if (object_dynamic_cast(OBJECT(dev), TYPE_MEMORY_DEVICE)) { > + memory_device_unplug(MACHINE(hotplug_dev), MEMORY_DEVICE(dev)); > + } > + } > error_propagate(errp, local_err); > } > > @@ -468,6 +486,16 @@ static void s390_machine_device_unplug(HotplugHandler > *hotplug_dev, > &local_err); > } > error_propagate(errp, local_err); > + > + if (local_err) { > + error_propagate(errp, local_err); > + return; > + } > + > + /* first stage hotplug handler */ > + if (object_dynamic_cast(OBJECT(dev), TYPE_MEMORY_DEVICE)) { > + memory_device_unplug(MACHINE(hotplug_dev), MEMORY_DEVICE(dev)); > + } > } > > static CpuInstanceProperties s390_cpu_index_to_props(MachineState *ms, > @@ -506,7 +534,8 @@ static const CPUArchIdList > *s390_possible_cpu_arch_ids(MachineState *ms) > static HotplugHandler *s390_get_hotplug_handler(MachineState *machine, > DeviceState *dev) > { > - if (object_dynamic_cast(OBJECT(dev), TYPE_CPU)) { > + if (object_dynamic_cast(OBJECT(dev), TYPE_CPU) || > + object_dynamic_cast(OBJECT(dev), TYPE_MEMORY_DEVICE)) { > return HOTPLUG_HANDLER(machine); > } > return NULL; >
Just noticed that this patch misses the pre plug handler here. I will wait for some feedback before I resend (and the !s390x patches can be picked up independently). -- Thanks, David / dhildenb