xref: /openbmc/qemu/hw/core/qdev.c (revision 1cf9412b)
1 /*
2  *  Dynamic device configuration and creation.
3  *
4  *  Copyright (c) 2009 CodeSourcery
5  *
6  * This library is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2 of the License, or (at your option) any later version.
10  *
11  * This library is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with this library; if not, see <http://www.gnu.org/licenses/>.
18  */
19 
20 /* The theory here is that it should be possible to create a machine without
21    knowledge of specific devices.  Historically board init routines have
22    passed a bunch of arguments to each device, requiring the board know
23    exactly which device it is dealing with.  This file provides an abstract
24    API for device configuration and initialization.  Devices will generally
25    inherit from a particular bus (e.g. PCI or I2C) rather than
26    this API directly.  */
27 
28 #include "hw/qdev.h"
29 #include "sysemu/sysemu.h"
30 #include "qapi/error.h"
31 #include "qapi/qmp/qerror.h"
32 #include "qapi/visitor.h"
33 #include "qapi/qmp/qjson.h"
34 #include "monitor/monitor.h"
35 
36 int qdev_hotplug = 0;
37 static bool qdev_hot_added = false;
38 static bool qdev_hot_removed = false;
39 
40 const VMStateDescription *qdev_get_vmsd(DeviceState *dev)
41 {
42     DeviceClass *dc = DEVICE_GET_CLASS(dev);
43     return dc->vmsd;
44 }
45 
46 const char *qdev_fw_name(DeviceState *dev)
47 {
48     DeviceClass *dc = DEVICE_GET_CLASS(dev);
49 
50     if (dc->fw_name) {
51         return dc->fw_name;
52     }
53 
54     return object_get_typename(OBJECT(dev));
55 }
56 
57 static void qdev_property_add_legacy(DeviceState *dev, Property *prop,
58                                      Error **errp);
59 
60 static void bus_remove_child(BusState *bus, DeviceState *child)
61 {
62     BusChild *kid;
63 
64     QTAILQ_FOREACH(kid, &bus->children, sibling) {
65         if (kid->child == child) {
66             char name[32];
67 
68             snprintf(name, sizeof(name), "child[%d]", kid->index);
69             QTAILQ_REMOVE(&bus->children, kid, sibling);
70 
71             /* This gives back ownership of kid->child back to us.  */
72             object_property_del(OBJECT(bus), name, NULL);
73             object_unref(OBJECT(kid->child));
74             g_free(kid);
75             return;
76         }
77     }
78 }
79 
80 static void bus_add_child(BusState *bus, DeviceState *child)
81 {
82     char name[32];
83     BusChild *kid = g_malloc0(sizeof(*kid));
84 
85     if (qdev_hotplug) {
86         assert(bus->allow_hotplug);
87     }
88 
89     kid->index = bus->max_index++;
90     kid->child = child;
91     object_ref(OBJECT(kid->child));
92 
93     QTAILQ_INSERT_HEAD(&bus->children, kid, sibling);
94 
95     /* This transfers ownership of kid->child to the property.  */
96     snprintf(name, sizeof(name), "child[%d]", kid->index);
97     object_property_add_link(OBJECT(bus), name,
98                              object_get_typename(OBJECT(child)),
99                              (Object **)&kid->child,
100                              NULL);
101 }
102 
103 void qdev_set_parent_bus(DeviceState *dev, BusState *bus)
104 {
105     dev->parent_bus = bus;
106     object_ref(OBJECT(bus));
107     bus_add_child(bus, dev);
108 }
109 
110 /* Create a new device.  This only initializes the device state structure
111    and allows properties to be set.  qdev_init should be called to
112    initialize the actual device emulation.  */
113 DeviceState *qdev_create(BusState *bus, const char *name)
114 {
115     DeviceState *dev;
116 
117     dev = qdev_try_create(bus, name);
118     if (!dev) {
119         if (bus) {
120             error_report("Unknown device '%s' for bus '%s'", name,
121                          object_get_typename(OBJECT(bus)));
122         } else {
123             error_report("Unknown device '%s' for default sysbus", name);
124         }
125         abort();
126     }
127 
128     return dev;
129 }
130 
131 DeviceState *qdev_try_create(BusState *bus, const char *type)
132 {
133     DeviceState *dev;
134 
135     if (object_class_by_name(type) == NULL) {
136         return NULL;
137     }
138     dev = DEVICE(object_new(type));
139     if (!dev) {
140         return NULL;
141     }
142 
143     if (!bus) {
144         bus = sysbus_get_default();
145     }
146 
147     qdev_set_parent_bus(dev, bus);
148     object_unref(OBJECT(dev));
149     return dev;
150 }
151 
152 /* Initialize a device.  Device properties should be set before calling
153    this function.  IRQs and MMIO regions should be connected/mapped after
154    calling this function.
155    On failure, destroy the device and return negative value.
156    Return 0 on success.  */
157 int qdev_init(DeviceState *dev)
158 {
159     Error *local_err = NULL;
160 
161     assert(!dev->realized);
162 
163     object_property_set_bool(OBJECT(dev), true, "realized", &local_err);
164     if (local_err != NULL) {
165         qerror_report_err(local_err);
166         error_free(local_err);
167         qdev_free(dev);
168         return -1;
169     }
170     return 0;
171 }
172 
173 static void device_realize(DeviceState *dev, Error **err)
174 {
175     DeviceClass *dc = DEVICE_GET_CLASS(dev);
176 
177     if (dc->init) {
178         int rc = dc->init(dev);
179         if (rc < 0) {
180             error_setg(err, "Device initialization failed.");
181             return;
182         }
183     }
184 }
185 
186 static void device_unrealize(DeviceState *dev, Error **errp)
187 {
188     DeviceClass *dc = DEVICE_GET_CLASS(dev);
189 
190     if (dc->exit) {
191         int rc = dc->exit(dev);
192         if (rc < 0) {
193             error_setg(errp, "Device exit failed.");
194             return;
195         }
196     }
197 }
198 
199 void qdev_set_legacy_instance_id(DeviceState *dev, int alias_id,
200                                  int required_for_version)
201 {
202     assert(!dev->realized);
203     dev->instance_id_alias = alias_id;
204     dev->alias_required_for_version = required_for_version;
205 }
206 
207 void qdev_unplug(DeviceState *dev, Error **errp)
208 {
209     DeviceClass *dc = DEVICE_GET_CLASS(dev);
210 
211     if (dev->parent_bus && !dev->parent_bus->allow_hotplug) {
212         error_set(errp, QERR_BUS_NO_HOTPLUG, dev->parent_bus->name);
213         return;
214     }
215     assert(dc->unplug != NULL);
216 
217     qdev_hot_removed = true;
218 
219     if (dc->unplug(dev) < 0) {
220         error_set(errp, QERR_UNDEFINED_ERROR);
221         return;
222     }
223 }
224 
225 static int qdev_reset_one(DeviceState *dev, void *opaque)
226 {
227     device_reset(dev);
228 
229     return 0;
230 }
231 
232 static int qbus_reset_one(BusState *bus, void *opaque)
233 {
234     BusClass *bc = BUS_GET_CLASS(bus);
235     if (bc->reset) {
236         return bc->reset(bus);
237     }
238     return 0;
239 }
240 
241 void qdev_reset_all(DeviceState *dev)
242 {
243     qdev_walk_children(dev, qdev_reset_one, qbus_reset_one, NULL);
244 }
245 
246 void qbus_reset_all(BusState *bus)
247 {
248     qbus_walk_children(bus, qdev_reset_one, qbus_reset_one, NULL);
249 }
250 
251 void qbus_reset_all_fn(void *opaque)
252 {
253     BusState *bus = opaque;
254     qbus_reset_all(bus);
255 }
256 
257 /* can be used as ->unplug() callback for the simple cases */
258 int qdev_simple_unplug_cb(DeviceState *dev)
259 {
260     /* just zap it */
261     qdev_free(dev);
262     return 0;
263 }
264 
265 
266 /* Like qdev_init(), but terminate program via error_report() instead of
267    returning an error value.  This is okay during machine creation.
268    Don't use for hotplug, because there callers need to recover from
269    failure.  Exception: if you know the device's init() callback can't
270    fail, then qdev_init_nofail() can't fail either, and is therefore
271    usable even then.  But relying on the device implementation that
272    way is somewhat unclean, and best avoided.  */
273 void qdev_init_nofail(DeviceState *dev)
274 {
275     const char *typename = object_get_typename(OBJECT(dev));
276 
277     if (qdev_init(dev) < 0) {
278         error_report("Initialization of device %s failed", typename);
279         exit(1);
280     }
281 }
282 
283 /* Unlink device from bus and free the structure.  */
284 void qdev_free(DeviceState *dev)
285 {
286     object_unparent(OBJECT(dev));
287 }
288 
289 void qdev_machine_creation_done(void)
290 {
291     /*
292      * ok, initial machine setup is done, starting from now we can
293      * only create hotpluggable devices
294      */
295     qdev_hotplug = 1;
296 }
297 
298 bool qdev_machine_modified(void)
299 {
300     return qdev_hot_added || qdev_hot_removed;
301 }
302 
303 BusState *qdev_get_parent_bus(DeviceState *dev)
304 {
305     return dev->parent_bus;
306 }
307 
308 void qdev_init_gpio_in(DeviceState *dev, qemu_irq_handler handler, int n)
309 {
310     dev->gpio_in = qemu_extend_irqs(dev->gpio_in, dev->num_gpio_in, handler,
311                                         dev, n);
312     dev->num_gpio_in += n;
313 }
314 
315 void qdev_init_gpio_out(DeviceState *dev, qemu_irq *pins, int n)
316 {
317     assert(dev->num_gpio_out == 0);
318     dev->num_gpio_out = n;
319     dev->gpio_out = pins;
320 }
321 
322 qemu_irq qdev_get_gpio_in(DeviceState *dev, int n)
323 {
324     assert(n >= 0 && n < dev->num_gpio_in);
325     return dev->gpio_in[n];
326 }
327 
328 void qdev_connect_gpio_out(DeviceState * dev, int n, qemu_irq pin)
329 {
330     assert(n >= 0 && n < dev->num_gpio_out);
331     dev->gpio_out[n] = pin;
332 }
333 
334 BusState *qdev_get_child_bus(DeviceState *dev, const char *name)
335 {
336     BusState *bus;
337 
338     QLIST_FOREACH(bus, &dev->child_bus, sibling) {
339         if (strcmp(name, bus->name) == 0) {
340             return bus;
341         }
342     }
343     return NULL;
344 }
345 
346 int qbus_walk_children(BusState *bus, qdev_walkerfn *devfn,
347                        qbus_walkerfn *busfn, void *opaque)
348 {
349     BusChild *kid;
350     int err;
351 
352     if (busfn) {
353         err = busfn(bus, opaque);
354         if (err) {
355             return err;
356         }
357     }
358 
359     QTAILQ_FOREACH(kid, &bus->children, sibling) {
360         err = qdev_walk_children(kid->child, devfn, busfn, opaque);
361         if (err < 0) {
362             return err;
363         }
364     }
365 
366     return 0;
367 }
368 
369 int qdev_walk_children(DeviceState *dev, qdev_walkerfn *devfn,
370                        qbus_walkerfn *busfn, void *opaque)
371 {
372     BusState *bus;
373     int err;
374 
375     if (devfn) {
376         err = devfn(dev, opaque);
377         if (err) {
378             return err;
379         }
380     }
381 
382     QLIST_FOREACH(bus, &dev->child_bus, sibling) {
383         err = qbus_walk_children(bus, devfn, busfn, opaque);
384         if (err < 0) {
385             return err;
386         }
387     }
388 
389     return 0;
390 }
391 
392 DeviceState *qdev_find_recursive(BusState *bus, const char *id)
393 {
394     BusChild *kid;
395     DeviceState *ret;
396     BusState *child;
397 
398     QTAILQ_FOREACH(kid, &bus->children, sibling) {
399         DeviceState *dev = kid->child;
400 
401         if (dev->id && strcmp(dev->id, id) == 0) {
402             return dev;
403         }
404 
405         QLIST_FOREACH(child, &dev->child_bus, sibling) {
406             ret = qdev_find_recursive(child, id);
407             if (ret) {
408                 return ret;
409             }
410         }
411     }
412     return NULL;
413 }
414 
415 static void qbus_realize(BusState *bus, DeviceState *parent, const char *name)
416 {
417     const char *typename = object_get_typename(OBJECT(bus));
418     char *buf;
419     int i,len;
420 
421     bus->parent = parent;
422 
423     if (name) {
424         bus->name = g_strdup(name);
425     } else if (bus->parent && bus->parent->id) {
426         /* parent device has id -> use it for bus name */
427         len = strlen(bus->parent->id) + 16;
428         buf = g_malloc(len);
429         snprintf(buf, len, "%s.%d", bus->parent->id, bus->parent->num_child_bus);
430         bus->name = buf;
431     } else {
432         /* no id -> use lowercase bus type for bus name */
433         len = strlen(typename) + 16;
434         buf = g_malloc(len);
435         len = snprintf(buf, len, "%s.%d", typename,
436                        bus->parent ? bus->parent->num_child_bus : 0);
437         for (i = 0; i < len; i++)
438             buf[i] = qemu_tolower(buf[i]);
439         bus->name = buf;
440     }
441 
442     if (bus->parent) {
443         QLIST_INSERT_HEAD(&bus->parent->child_bus, bus, sibling);
444         bus->parent->num_child_bus++;
445         object_property_add_child(OBJECT(bus->parent), bus->name, OBJECT(bus), NULL);
446         object_unref(OBJECT(bus));
447     } else if (bus != sysbus_get_default()) {
448         /* TODO: once all bus devices are qdevified,
449            only reset handler for main_system_bus should be registered here. */
450         qemu_register_reset(qbus_reset_all_fn, bus);
451     }
452 }
453 
454 static void bus_unparent(Object *obj)
455 {
456     BusState *bus = BUS(obj);
457     BusChild *kid;
458 
459     while ((kid = QTAILQ_FIRST(&bus->children)) != NULL) {
460         DeviceState *dev = kid->child;
461         qdev_free(dev);
462     }
463     if (bus->parent) {
464         QLIST_REMOVE(bus, sibling);
465         bus->parent->num_child_bus--;
466         bus->parent = NULL;
467     } else {
468         assert(bus != sysbus_get_default()); /* main_system_bus is never freed */
469         qemu_unregister_reset(qbus_reset_all_fn, bus);
470     }
471 }
472 
473 void qbus_create_inplace(void *bus, size_t size, const char *typename,
474                          DeviceState *parent, const char *name)
475 {
476     object_initialize(bus, size, typename);
477     qbus_realize(bus, parent, name);
478 }
479 
480 BusState *qbus_create(const char *typename, DeviceState *parent, const char *name)
481 {
482     BusState *bus;
483 
484     bus = BUS(object_new(typename));
485     qbus_realize(bus, parent, name);
486 
487     return bus;
488 }
489 
490 void qbus_free(BusState *bus)
491 {
492     object_unparent(OBJECT(bus));
493 }
494 
495 static char *bus_get_fw_dev_path(BusState *bus, DeviceState *dev)
496 {
497     BusClass *bc = BUS_GET_CLASS(bus);
498 
499     if (bc->get_fw_dev_path) {
500         return bc->get_fw_dev_path(dev);
501     }
502 
503     return NULL;
504 }
505 
506 static int qdev_get_fw_dev_path_helper(DeviceState *dev, char *p, int size)
507 {
508     int l = 0;
509 
510     if (dev && dev->parent_bus) {
511         char *d;
512         l = qdev_get_fw_dev_path_helper(dev->parent_bus->parent, p, size);
513         d = bus_get_fw_dev_path(dev->parent_bus, dev);
514         if (d) {
515             l += snprintf(p + l, size - l, "%s", d);
516             g_free(d);
517         } else {
518             return l;
519         }
520     }
521     l += snprintf(p + l , size - l, "/");
522 
523     return l;
524 }
525 
526 char* qdev_get_fw_dev_path(DeviceState *dev)
527 {
528     char path[128];
529     int l;
530 
531     l = qdev_get_fw_dev_path_helper(dev, path, 128);
532 
533     path[l-1] = '\0';
534 
535     return g_strdup(path);
536 }
537 
538 char *qdev_get_dev_path(DeviceState *dev)
539 {
540     BusClass *bc;
541 
542     if (!dev || !dev->parent_bus) {
543         return NULL;
544     }
545 
546     bc = BUS_GET_CLASS(dev->parent_bus);
547     if (bc->get_dev_path) {
548         return bc->get_dev_path(dev);
549     }
550 
551     return NULL;
552 }
553 
554 /**
555  * Legacy property handling
556  */
557 
558 static void qdev_get_legacy_property(Object *obj, Visitor *v, void *opaque,
559                                      const char *name, Error **errp)
560 {
561     DeviceState *dev = DEVICE(obj);
562     Property *prop = opaque;
563 
564     char buffer[1024];
565     char *ptr = buffer;
566 
567     prop->info->print(dev, prop, buffer, sizeof(buffer));
568     visit_type_str(v, &ptr, name, errp);
569 }
570 
571 static void qdev_set_legacy_property(Object *obj, Visitor *v, void *opaque,
572                                      const char *name, Error **errp)
573 {
574     DeviceState *dev = DEVICE(obj);
575     Property *prop = opaque;
576     Error *local_err = NULL;
577     char *ptr = NULL;
578     int ret;
579 
580     if (dev->realized) {
581         qdev_prop_set_after_realize(dev, name, errp);
582         return;
583     }
584 
585     visit_type_str(v, &ptr, name, &local_err);
586     if (local_err) {
587         error_propagate(errp, local_err);
588         return;
589     }
590 
591     ret = prop->info->parse(dev, prop, ptr);
592     error_set_from_qdev_prop_error(errp, ret, dev, prop, ptr);
593     g_free(ptr);
594 }
595 
596 /**
597  * @qdev_add_legacy_property - adds a legacy property
598  *
599  * Do not use this is new code!  Properties added through this interface will
600  * be given names and types in the "legacy" namespace.
601  *
602  * Legacy properties are string versions of other OOM properties.  The format
603  * of the string depends on the property type.
604  */
605 void qdev_property_add_legacy(DeviceState *dev, Property *prop,
606                               Error **errp)
607 {
608     gchar *name, *type;
609 
610     /* Register pointer properties as legacy properties */
611     if (!prop->info->print && !prop->info->parse &&
612         (prop->info->set || prop->info->get)) {
613         return;
614     }
615 
616     name = g_strdup_printf("legacy-%s", prop->name);
617     type = g_strdup_printf("legacy<%s>",
618                            prop->info->legacy_name ?: prop->info->name);
619 
620     object_property_add(OBJECT(dev), name, type,
621                         prop->info->print ? qdev_get_legacy_property : prop->info->get,
622                         prop->info->parse ? qdev_set_legacy_property : prop->info->set,
623                         NULL,
624                         prop, errp);
625 
626     g_free(type);
627     g_free(name);
628 }
629 
630 /**
631  * @qdev_property_add_static - add a @Property to a device.
632  *
633  * Static properties access data in a struct.  The actual type of the
634  * property and the field depends on the property type.
635  */
636 void qdev_property_add_static(DeviceState *dev, Property *prop,
637                               Error **errp)
638 {
639     Error *local_err = NULL;
640     Object *obj = OBJECT(dev);
641 
642     /*
643      * TODO qdev_prop_ptr does not have getters or setters.  It must
644      * go now that it can be replaced with links.  The test should be
645      * removed along with it: all static properties are read/write.
646      */
647     if (!prop->info->get && !prop->info->set) {
648         return;
649     }
650 
651     object_property_add(obj, prop->name, prop->info->name,
652                         prop->info->get, prop->info->set,
653                         prop->info->release,
654                         prop, &local_err);
655 
656     if (local_err) {
657         error_propagate(errp, local_err);
658         return;
659     }
660     if (prop->qtype == QTYPE_NONE) {
661         return;
662     }
663 
664     if (prop->qtype == QTYPE_QBOOL) {
665         object_property_set_bool(obj, prop->defval, prop->name, &local_err);
666     } else if (prop->info->enum_table) {
667         object_property_set_str(obj, prop->info->enum_table[prop->defval],
668                                 prop->name, &local_err);
669     } else if (prop->qtype == QTYPE_QINT) {
670         object_property_set_int(obj, prop->defval, prop->name, &local_err);
671     }
672     assert_no_error(local_err);
673 }
674 
675 static bool device_get_realized(Object *obj, Error **err)
676 {
677     DeviceState *dev = DEVICE(obj);
678     return dev->realized;
679 }
680 
681 static void device_set_realized(Object *obj, bool value, Error **err)
682 {
683     DeviceState *dev = DEVICE(obj);
684     DeviceClass *dc = DEVICE_GET_CLASS(dev);
685     Error *local_err = NULL;
686 
687     if (value && !dev->realized) {
688         if (!obj->parent && local_err == NULL) {
689             static int unattached_count;
690             gchar *name = g_strdup_printf("device[%d]", unattached_count++);
691 
692             object_property_add_child(container_get(qdev_get_machine(),
693                                                     "/unattached"),
694                                       name, obj, &local_err);
695             g_free(name);
696         }
697 
698         if (dc->realize) {
699             dc->realize(dev, &local_err);
700         }
701 
702         if (qdev_get_vmsd(dev) && local_err == NULL) {
703             vmstate_register_with_alias_id(dev, -1, qdev_get_vmsd(dev), dev,
704                                            dev->instance_id_alias,
705                                            dev->alias_required_for_version);
706         }
707         if (dev->hotplugged && local_err == NULL) {
708             device_reset(dev);
709         }
710     } else if (!value && dev->realized) {
711         if (qdev_get_vmsd(dev)) {
712             vmstate_unregister(dev, qdev_get_vmsd(dev), dev);
713         }
714         if (dc->unrealize) {
715             dc->unrealize(dev, &local_err);
716         }
717     }
718 
719     if (local_err != NULL) {
720         error_propagate(err, local_err);
721         return;
722     }
723 
724     dev->realized = value;
725 }
726 
727 static void device_initfn(Object *obj)
728 {
729     DeviceState *dev = DEVICE(obj);
730     ObjectClass *class;
731     Property *prop;
732     Error *err = NULL;
733 
734     if (qdev_hotplug) {
735         dev->hotplugged = 1;
736         qdev_hot_added = true;
737     }
738 
739     dev->instance_id_alias = -1;
740     dev->realized = false;
741 
742     object_property_add_bool(obj, "realized",
743                              device_get_realized, device_set_realized, NULL);
744 
745     class = object_get_class(OBJECT(dev));
746     do {
747         for (prop = DEVICE_CLASS(class)->props; prop && prop->name; prop++) {
748             qdev_property_add_legacy(dev, prop, &err);
749             assert_no_error(err);
750             qdev_property_add_static(dev, prop, &err);
751             assert_no_error(err);
752         }
753         class = object_class_get_parent(class);
754     } while (class != object_class_by_name(TYPE_DEVICE));
755     if (err != NULL) {
756         qerror_report_err(err);
757         error_free(err);
758         exit(1);
759     }
760 
761     object_property_add_link(OBJECT(dev), "parent_bus", TYPE_BUS,
762                              (Object **)&dev->parent_bus, &err);
763     assert_no_error(err);
764 }
765 
766 static void device_post_init(Object *obj)
767 {
768     DeviceState *dev = DEVICE(obj);
769     Error *err = NULL;
770 
771     qdev_prop_set_globals(dev, &err);
772     assert_no_error(err);
773 }
774 
775 /* Unlink device from bus and free the structure.  */
776 static void device_finalize(Object *obj)
777 {
778     DeviceState *dev = DEVICE(obj);
779     if (dev->opts) {
780         qemu_opts_del(dev->opts);
781     }
782 }
783 
784 static void device_class_base_init(ObjectClass *class, void *data)
785 {
786     DeviceClass *klass = DEVICE_CLASS(class);
787 
788     /* We explicitly look up properties in the superclasses,
789      * so do not propagate them to the subclasses.
790      */
791     klass->props = NULL;
792 }
793 
794 static void device_unparent(Object *obj)
795 {
796     DeviceState *dev = DEVICE(obj);
797     BusState *bus;
798     QObject *event_data;
799     bool have_realized = dev->realized;
800 
801     while (dev->num_child_bus) {
802         bus = QLIST_FIRST(&dev->child_bus);
803         qbus_free(bus);
804     }
805     if (dev->realized) {
806         object_property_set_bool(obj, false, "realized", NULL);
807     }
808     if (dev->parent_bus) {
809         bus_remove_child(dev->parent_bus, dev);
810         object_unref(OBJECT(dev->parent_bus));
811         dev->parent_bus = NULL;
812     }
813 
814     /* Only send event if the device had been completely realized */
815     if (have_realized) {
816         gchar *path = object_get_canonical_path(OBJECT(dev));
817 
818         if (dev->id) {
819             event_data = qobject_from_jsonf("{ 'device': %s, 'path': %s }",
820                                             dev->id, path);
821         } else {
822             event_data = qobject_from_jsonf("{ 'path': %s }", path);
823         }
824         monitor_protocol_event(QEVENT_DEVICE_DELETED, event_data);
825         qobject_decref(event_data);
826         g_free(path);
827     }
828 }
829 
830 static void device_class_init(ObjectClass *class, void *data)
831 {
832     DeviceClass *dc = DEVICE_CLASS(class);
833 
834     class->unparent = device_unparent;
835     dc->realize = device_realize;
836     dc->unrealize = device_unrealize;
837 }
838 
839 void device_reset(DeviceState *dev)
840 {
841     DeviceClass *klass = DEVICE_GET_CLASS(dev);
842 
843     if (klass->reset) {
844         klass->reset(dev);
845     }
846 }
847 
848 Object *qdev_get_machine(void)
849 {
850     static Object *dev;
851 
852     if (dev == NULL) {
853         dev = container_get(object_get_root(), "/machine");
854     }
855 
856     return dev;
857 }
858 
859 static const TypeInfo device_type_info = {
860     .name = TYPE_DEVICE,
861     .parent = TYPE_OBJECT,
862     .instance_size = sizeof(DeviceState),
863     .instance_init = device_initfn,
864     .instance_post_init = device_post_init,
865     .instance_finalize = device_finalize,
866     .class_base_init = device_class_base_init,
867     .class_init = device_class_init,
868     .abstract = true,
869     .class_size = sizeof(DeviceClass),
870 };
871 
872 static void qbus_initfn(Object *obj)
873 {
874     BusState *bus = BUS(obj);
875 
876     QTAILQ_INIT(&bus->children);
877 }
878 
879 static char *default_bus_get_fw_dev_path(DeviceState *dev)
880 {
881     return g_strdup(object_get_typename(OBJECT(dev)));
882 }
883 
884 static void bus_class_init(ObjectClass *class, void *data)
885 {
886     BusClass *bc = BUS_CLASS(class);
887 
888     class->unparent = bus_unparent;
889     bc->get_fw_dev_path = default_bus_get_fw_dev_path;
890 }
891 
892 static void qbus_finalize(Object *obj)
893 {
894     BusState *bus = BUS(obj);
895 
896     g_free((char *)bus->name);
897 }
898 
899 static const TypeInfo bus_info = {
900     .name = TYPE_BUS,
901     .parent = TYPE_OBJECT,
902     .instance_size = sizeof(BusState),
903     .abstract = true,
904     .class_size = sizeof(BusClass),
905     .instance_init = qbus_initfn,
906     .instance_finalize = qbus_finalize,
907     .class_init = bus_class_init,
908 };
909 
910 static void qdev_register_types(void)
911 {
912     type_register_static(&bus_info);
913     type_register_static(&device_type_info);
914 }
915 
916 type_init(qdev_register_types)
917