diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/base/bus.c | 34 | ||||
-rw-r--r-- | drivers/base/core.c | 17 | ||||
-rw-r--r-- | drivers/base/driver.c | 15 |
3 files changed, 62 insertions, 4 deletions
diff --git a/drivers/base/bus.c b/drivers/base/bus.c index 17e96698410e..03204bfd17af 100644 --- a/drivers/base/bus.c +++ b/drivers/base/bus.c | |||
@@ -568,6 +568,36 @@ static void bus_remove_attrs(struct bus_type * bus) | |||
568 | } | 568 | } |
569 | } | 569 | } |
570 | 570 | ||
571 | static void klist_devices_get(struct klist_node *n) | ||
572 | { | ||
573 | struct device *dev = container_of(n, struct device, knode_bus); | ||
574 | |||
575 | get_device(dev); | ||
576 | } | ||
577 | |||
578 | static void klist_devices_put(struct klist_node *n) | ||
579 | { | ||
580 | struct device *dev = container_of(n, struct device, knode_bus); | ||
581 | |||
582 | put_device(dev); | ||
583 | } | ||
584 | |||
585 | static void klist_drivers_get(struct klist_node *n) | ||
586 | { | ||
587 | struct device_driver *drv = container_of(n, struct device_driver, | ||
588 | knode_bus); | ||
589 | |||
590 | get_driver(drv); | ||
591 | } | ||
592 | |||
593 | static void klist_drivers_put(struct klist_node *n) | ||
594 | { | ||
595 | struct device_driver *drv = container_of(n, struct device_driver, | ||
596 | knode_bus); | ||
597 | |||
598 | put_driver(drv); | ||
599 | } | ||
600 | |||
571 | /** | 601 | /** |
572 | * bus_register - register a bus with the system. | 602 | * bus_register - register a bus with the system. |
573 | * @bus: bus. | 603 | * @bus: bus. |
@@ -602,8 +632,8 @@ int bus_register(struct bus_type * bus) | |||
602 | if (retval) | 632 | if (retval) |
603 | goto bus_drivers_fail; | 633 | goto bus_drivers_fail; |
604 | 634 | ||
605 | klist_init(&bus->klist_devices); | 635 | klist_init(&bus->klist_devices, klist_devices_get, klist_devices_put); |
606 | klist_init(&bus->klist_drivers); | 636 | klist_init(&bus->klist_drivers, klist_drivers_get, klist_drivers_put); |
607 | bus_add_attrs(bus); | 637 | bus_add_attrs(bus); |
608 | 638 | ||
609 | pr_debug("bus type '%s' registered\n", bus->name); | 639 | pr_debug("bus type '%s' registered\n", bus->name); |
diff --git a/drivers/base/core.c b/drivers/base/core.c index c8a33df00761..6ab73f5c799a 100644 --- a/drivers/base/core.c +++ b/drivers/base/core.c | |||
@@ -191,6 +191,20 @@ void device_remove_file(struct device * dev, struct device_attribute * attr) | |||
191 | } | 191 | } |
192 | } | 192 | } |
193 | 193 | ||
194 | static void klist_children_get(struct klist_node *n) | ||
195 | { | ||
196 | struct device *dev = container_of(n, struct device, knode_parent); | ||
197 | |||
198 | get_device(dev); | ||
199 | } | ||
200 | |||
201 | static void klist_children_put(struct klist_node *n) | ||
202 | { | ||
203 | struct device *dev = container_of(n, struct device, knode_parent); | ||
204 | |||
205 | put_device(dev); | ||
206 | } | ||
207 | |||
194 | 208 | ||
195 | /** | 209 | /** |
196 | * device_initialize - init device structure. | 210 | * device_initialize - init device structure. |
@@ -207,7 +221,8 @@ void device_initialize(struct device *dev) | |||
207 | { | 221 | { |
208 | kobj_set_kset_s(dev, devices_subsys); | 222 | kobj_set_kset_s(dev, devices_subsys); |
209 | kobject_init(&dev->kobj); | 223 | kobject_init(&dev->kobj); |
210 | klist_init(&dev->klist_children); | 224 | klist_init(&dev->klist_children, klist_children_get, |
225 | klist_children_put); | ||
211 | INIT_LIST_HEAD(&dev->dma_pools); | 226 | INIT_LIST_HEAD(&dev->dma_pools); |
212 | init_MUTEX(&dev->sem); | 227 | init_MUTEX(&dev->sem); |
213 | } | 228 | } |
diff --git a/drivers/base/driver.c b/drivers/base/driver.c index 291c5954a3af..ef3fe513e398 100644 --- a/drivers/base/driver.c +++ b/drivers/base/driver.c | |||
@@ -142,6 +142,19 @@ void put_driver(struct device_driver * drv) | |||
142 | kobject_put(&drv->kobj); | 142 | kobject_put(&drv->kobj); |
143 | } | 143 | } |
144 | 144 | ||
145 | static void klist_devices_get(struct klist_node *n) | ||
146 | { | ||
147 | struct device *dev = container_of(n, struct device, knode_driver); | ||
148 | |||
149 | get_device(dev); | ||
150 | } | ||
151 | |||
152 | static void klist_devices_put(struct klist_node *n) | ||
153 | { | ||
154 | struct device *dev = container_of(n, struct device, knode_driver); | ||
155 | |||
156 | put_device(dev); | ||
157 | } | ||
145 | 158 | ||
146 | /** | 159 | /** |
147 | * driver_register - register driver with bus | 160 | * driver_register - register driver with bus |
@@ -157,7 +170,7 @@ void put_driver(struct device_driver * drv) | |||
157 | */ | 170 | */ |
158 | int driver_register(struct device_driver * drv) | 171 | int driver_register(struct device_driver * drv) |
159 | { | 172 | { |
160 | klist_init(&drv->klist_devices); | 173 | klist_init(&drv->klist_devices, klist_devices_get, klist_devices_put); |
161 | init_completion(&drv->unloaded); | 174 | init_completion(&drv->unloaded); |
162 | return bus_add_driver(drv); | 175 | return bus_add_driver(drv); |
163 | } | 176 | } |