qdev: refactor away qdev_create_from_info
Note that the FIXME gets fixed in series 4/4. We need to convert BusState to QOM before we can make parent_bus a link. Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
parent
9674bfe420
commit
9fbe61277f
35
hw/qdev.c
35
hw/qdev.c
@ -124,30 +124,22 @@ bool qdev_exists(const char *name)
|
|||||||
static void qdev_property_add_legacy(DeviceState *dev, Property *prop,
|
static void qdev_property_add_legacy(DeviceState *dev, Property *prop,
|
||||||
Error **errp);
|
Error **errp);
|
||||||
|
|
||||||
static DeviceState *qdev_create_from_info(BusState *bus, const char *typename)
|
void qdev_set_parent_bus(DeviceState *dev, BusState *bus)
|
||||||
{
|
{
|
||||||
DeviceState *dev;
|
|
||||||
Property *prop;
|
Property *prop;
|
||||||
|
|
||||||
dev = DEVICE(object_new(typename));
|
|
||||||
|
|
||||||
dev->parent_bus = bus;
|
|
||||||
qdev_prop_set_defaults(dev, dev->parent_bus->info->props);
|
|
||||||
|
|
||||||
if (qdev_hotplug) {
|
if (qdev_hotplug) {
|
||||||
assert(bus->allow_hotplug);
|
assert(bus->allow_hotplug);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
dev->parent_bus = bus;
|
||||||
QTAILQ_INSERT_HEAD(&bus->children, dev, sibling);
|
QTAILQ_INSERT_HEAD(&bus->children, dev, sibling);
|
||||||
|
|
||||||
|
qdev_prop_set_defaults(dev, dev->parent_bus->info->props);
|
||||||
for (prop = qdev_get_bus_info(dev)->props; prop && prop->name; prop++) {
|
for (prop = qdev_get_bus_info(dev)->props; prop && prop->name; prop++) {
|
||||||
qdev_property_add_legacy(dev, prop, NULL);
|
qdev_property_add_legacy(dev, prop, NULL);
|
||||||
qdev_property_add_static(dev, prop, NULL);
|
qdev_property_add_static(dev, prop, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
qdev_prop_set_globals(dev);
|
|
||||||
|
|
||||||
return dev;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Create a new device. This only initializes the device state structure
|
/* Create a new device. This only initializes the device state structure
|
||||||
@ -172,11 +164,21 @@ DeviceState *qdev_create(BusState *bus, const char *name)
|
|||||||
|
|
||||||
DeviceState *qdev_try_create(BusState *bus, const char *name)
|
DeviceState *qdev_try_create(BusState *bus, const char *name)
|
||||||
{
|
{
|
||||||
|
DeviceState *dev;
|
||||||
|
|
||||||
|
dev = DEVICE(object_new(name));
|
||||||
|
if (!dev) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
if (!bus) {
|
if (!bus) {
|
||||||
bus = sysbus_get_default();
|
bus = sysbus_get_default();
|
||||||
}
|
}
|
||||||
|
|
||||||
return qdev_create_from_info(bus, name);
|
qdev_set_parent_bus(dev, bus);
|
||||||
|
qdev_prop_set_globals(dev);
|
||||||
|
|
||||||
|
return dev;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void qdev_print_devinfo(ObjectClass *klass, void *opaque)
|
static void qdev_print_devinfo(ObjectClass *klass, void *opaque)
|
||||||
@ -373,8 +375,15 @@ DeviceState *qdev_device_add(QemuOpts *opts)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!bus) {
|
||||||
|
bus = sysbus_get_default();
|
||||||
|
}
|
||||||
|
|
||||||
/* create device, set properties */
|
/* create device, set properties */
|
||||||
qdev = qdev_create_from_info(bus, driver);
|
qdev = DEVICE(object_new(driver));
|
||||||
|
qdev_set_parent_bus(qdev, bus);
|
||||||
|
qdev_prop_set_globals(qdev);
|
||||||
|
|
||||||
id = qemu_opts_id(opts);
|
id = qemu_opts_id(opts);
|
||||||
if (id) {
|
if (id) {
|
||||||
qdev->id = id;
|
qdev->id = id;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user