diff options
author | Sascha Hauer <s.hauer@pengutronix.de> | 2023-03-17 09:48:40 +0100 |
---|---|---|
committer | Sascha Hauer <s.hauer@pengutronix.de> | 2023-03-21 15:59:19 +0100 |
commit | 21f9fecba25d9ed744385007a18fd3267b786ea0 (patch) | |
tree | 4b8136fb8f4a57a69af0bfdfe9eab6b0cb01c587 /drivers/base | |
parent | 226f325973fc830f5ee93f64db9994d5f8602de7 (diff) | |
download | barebox-21f9fecba25d9ed744385007a18fd3267b786ea0.tar.gz barebox-21f9fecba25d9ed744385007a18fd3267b786ea0.tar.xz |
driver: Add unregister_driver()
Registering drivers is one thing, getting rid of them another. Add
unregister_driver() which is used in the coming USB gadget update.
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
Diffstat (limited to 'drivers/base')
-rw-r--r-- | drivers/base/driver.c | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/drivers/base/driver.c b/drivers/base/driver.c index efbffcdddb..f00be99cdc 100644 --- a/drivers/base/driver.c +++ b/drivers/base/driver.c @@ -405,6 +405,23 @@ int register_driver(struct driver *drv) } EXPORT_SYMBOL(register_driver); +void unregister_driver(struct driver *drv) +{ + struct device *dev; + + list_del(&drv->list); + list_del(&drv->bus_list); + + bus_for_each_device(drv->bus, dev) { + if (dev->driver == drv) { + drv->bus->remove(dev); + dev->driver = NULL; + list_del(&dev->active); + INIT_LIST_HEAD(&dev->active); + } + } +} + struct resource *dev_get_resource(struct device *dev, unsigned long type, int num) { |