From: Andreas Färber Date: Fri, 4 Jan 2013 17:13:00 +0000 (+0100) Subject: qdev: Don't assume existence of parent bus on unparenting X-Git-Tag: TizenStudio_2.0_p2.3.2~208^2~2850^2~12 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=5d5b24d042072fb4d13e7027f6e52e44390a9896;p=sdk%2Femulator%2Fqemu.git qdev: Don't assume existence of parent bus on unparenting Commit 667d22d1ae59da46b4c1fbd094ca61145f19b8c3 (qdev: move bus removal to object_unparent) made the assumption that at unparenting time parent_bus is not NULL. This assumption is unjustified since object_unparent() may well be called directly after object_initialize(), without any qdev_set_parent_bus(). This did not cause any issues yet because qdev_[try_]create() does call qdev_set_parent_bus(), falling back to SysBus if unsupplied. While at it, ensure that this new function uses the device_ prefix and make the name more neutral in light of this semantic change. Reported-by: Eduardo Habkost Signed-off-by: Andreas Färber Tested-by: Igor Mammedov --- diff --git a/hw/qdev.c b/hw/qdev.c index f2c2484..e2a5c57 100644 --- a/hw/qdev.c +++ b/hw/qdev.c @@ -698,16 +698,18 @@ static void device_class_base_init(ObjectClass *class, void *data) klass->props = NULL; } -static void qdev_remove_from_bus(Object *obj) +static void device_unparent(Object *obj) { DeviceState *dev = DEVICE(obj); - bus_remove_child(dev->parent_bus, dev); + if (dev->parent_bus != NULL) { + bus_remove_child(dev->parent_bus, dev); + } } static void device_class_init(ObjectClass *class, void *data) { - class->unparent = qdev_remove_from_bus; + class->unparent = device_unparent; } void device_reset(DeviceState *dev)