From 4e77d3c6a200814af7ec3f6745095c43b7e17c91 Mon Sep 17 00:00:00 2001 From: David Xu Date: Wed, 15 Jan 2003 14:58:07 +0000 Subject: [PATCH] Don't forget to disconnect object from class. --- sys/kern/subr_bus.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/sys/kern/subr_bus.c b/sys/kern/subr_bus.c index 0732e3b5b701..d562a438d287 100644 --- a/sys/kern/subr_bus.c +++ b/sys/kern/subr_bus.c @@ -240,7 +240,7 @@ struct dev_event_info TAILQ_HEAD(devq, dev_event_info); -struct dev_softc +struct dev_softc { int inuse; int nonblock; @@ -996,7 +996,7 @@ device_delete_child(device_t dev, device_t child) TAILQ_REMOVE(&dev->children, child, link); TAILQ_REMOVE(&bus_data_devices, child, devlink); device_set_desc(child, NULL); - free(child, M_BUS); + kobj_delete((kobj_t) child, M_BUS); bus_data_generation_update(); return (0); @@ -1417,6 +1417,7 @@ device_set_driver(device_t dev, driver_t *driver) dev->softc = malloc(driver->size, M_BUS, M_NOWAIT | M_ZERO); if (!dev->softc) { + kobj_delete((kobj_t) dev, 0); kobj_init((kobj_t) dev, &null_class); dev->driver = NULL; return (ENOMEM);