[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v3 07/33] serial: register vmsd with DeviceClass
From: |
Marc-André Lureau |
Subject: |
[PATCH v3 07/33] serial: register vmsd with DeviceClass |
Date: |
Wed, 23 Oct 2019 19:31:28 +0200 |
QOM-ify further.
Signed-off-by: Marc-André Lureau <address@hidden>
---
hw/char/serial.c | 13 ++++++++++---
1 file changed, 10 insertions(+), 3 deletions(-)
diff --git a/hw/char/serial.c b/hw/char/serial.c
index c839035fdd..4af8b0ce4c 100644
--- a/hw/char/serial.c
+++ b/hw/char/serial.c
@@ -990,8 +990,7 @@ SerialState *serial_init(int base, qemu_irq irq, int
baudbase,
s->baudbase = baudbase;
qemu_chr_fe_init(&s->chr, chr, &error_abort);
serial_realize_core(s, &error_fatal);
-
- vmstate_register(NULL, base, &vmstate_serial, s);
+ qdev_set_legacy_instance_id(dev, base, 2);
qdev_init_nofail(dev);
memory_region_init_io(&s->io, NULL, &serial_io_ops, s, "serial", 8);
@@ -1000,9 +999,17 @@ SerialState *serial_init(int base, qemu_irq irq, int
baudbase,
return s;
}
+static void serial_class_init(ObjectClass *klass, void* data)
+{
+ DeviceClass *dc = DEVICE_CLASS(klass);
+
+ dc->vmsd = &vmstate_serial;
+}
+
static const TypeInfo serial_info = {
.name = TYPE_SERIAL,
.parent = TYPE_DEVICE,
+ .class_init = serial_class_init,
.instance_size = sizeof(SerialState),
};
@@ -1060,7 +1067,7 @@ SerialState *serial_mm_init(MemoryRegion *address_space,
qemu_chr_fe_init(&s->chr, chr, &error_abort);
serial_realize_core(s, &error_fatal);
- vmstate_register(NULL, base, &vmstate_serial, s);
+ qdev_set_legacy_instance_id(dev, base, 2);
qdev_init_nofail(dev);
memory_region_init_io(&s->io, NULL, &serial_mm_ops[end], s,
--
2.23.0.606.g08da6496b6
- [PATCH v3 02/33] sysbus: remove unused sysbus_try_create*, (continued)
- [PATCH v3 02/33] sysbus: remove unused sysbus_try_create*, Marc-André Lureau, 2019/10/23
- [PATCH v3 03/33] sysbus: remove outdated comment, Marc-André Lureau, 2019/10/23
- [PATCH v3 04/33] chardev: generate an internal id when none given, Marc-André Lureau, 2019/10/23
- [PATCH v3 05/33] serial-pci-multi: factor out multi_serial_get_nr_ports, Marc-André Lureau, 2019/10/23
- [PATCH v3 06/33] serial: initial qom-ification, Marc-André Lureau, 2019/10/23
- [PATCH v3 07/33] serial: register vmsd with DeviceClass,
Marc-André Lureau <=
- [PATCH v3 08/33] serial: add "chardev" property, Marc-André Lureau, 2019/10/23
- [PATCH v3 09/33] serial: add "baudbase" property, Marc-André Lureau, 2019/10/23
- [PATCH v3 10/33] serial: add "instance-id" property, Marc-André Lureau, 2019/10/23
- [PATCH v3 11/33] serial: realize the serial device, Marc-André Lureau, 2019/10/23
- [PATCH v3 13/33] serial: start making SerialMM a sysbus device, Marc-André Lureau, 2019/10/23
- [PATCH v3 12/33] serial: replace serial_exit_core() with unrealize, Marc-André Lureau, 2019/10/23
- [PATCH v3 14/33] serial-mm: add "regshift" property, Marc-André Lureau, 2019/10/23
- [PATCH v3 16/33] serial-mm: use sysbus facilities, Marc-André Lureau, 2019/10/23