summaryrefslogtreecommitdiffstats
path: root/drivers/base
diff options
context:
space:
mode:
authorAlan Stern <stern@rowland.harvard.edu>2006-03-31 18:52:25 +0200
committerGreg Kroah-Hartman <gregkh@suse.de>2006-04-14 20:41:24 +0200
commit0f836ca4c122f4ef096110d652a6326fe34e6961 (patch)
tree5b249f2f255a7260d1a8926eb0a9e6d7e45ac524 /drivers/base
parent[PATCH] sysfs: Allow sysfs attribute files to be pollable (diff)
downloadlinux-0f836ca4c122f4ef096110d652a6326fe34e6961.tar.xz
linux-0f836ca4c122f4ef096110d652a6326fe34e6961.zip
[PATCH] driver core: safely unbind drivers for devices not on a bus
This patch (as667) changes the __device_release_driver() routine to prevent it from crashing when it runs across a device not on any bus. This seems logical, inasmuch as the corresponding bus_add_device() routine has an explicit check allowing it to accept such devices. Signed-off-by: Alan Stern <stern@rowland.harvard.edu> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/base')
-rw-r--r--drivers/base/dd.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/base/dd.c b/drivers/base/dd.c
index 730a9ce0a14a..889c71111239 100644
--- a/drivers/base/dd.c
+++ b/drivers/base/dd.c
@@ -209,7 +209,7 @@ static void __device_release_driver(struct device * dev)
sysfs_remove_link(&dev->kobj, "driver");
klist_remove(&dev->knode_driver);
- if (dev->bus->remove)
+ if (dev->bus && dev->bus->remove)
dev->bus->remove(dev);
else if (drv->remove)
drv->remove(dev);