summaryrefslogtreecommitdiffstats
path: root/drivers/base
diff options
context:
space:
mode:
authorSascha Hauer <s.hauer@pengutronix.de>2023-03-17 09:48:40 +0100
committerSascha Hauer <s.hauer@pengutronix.de>2023-03-21 15:59:19 +0100
commit21f9fecba25d9ed744385007a18fd3267b786ea0 (patch)
tree4b8136fb8f4a57a69af0bfdfe9eab6b0cb01c587 /drivers/base
parent226f325973fc830f5ee93f64db9994d5f8602de7 (diff)
downloadbarebox-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.c17
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)
{