1
2
3
4
5
6
7
8
9
10
11#include <linux/async.h>
12#include <linux/device/bus.h>
13#include <linux/device.h>
14#include <linux/module.h>
15#include <linux/errno.h>
16#include <linux/slab.h>
17#include <linux/init.h>
18#include <linux/string.h>
19#include <linux/mutex.h>
20#include <linux/sysfs.h>
21#include "base.h"
22#include "power/power.h"
23
24
25static struct kset *system_kset;
26
27#define to_bus_attr(_attr) container_of(_attr, struct bus_attribute, attr)
28
29
30
31
32
33#define to_drv_attr(_attr) container_of(_attr, struct driver_attribute, attr)
34
35#define DRIVER_ATTR_IGNORE_LOCKDEP(_name, _mode, _show, _store) \
36 struct driver_attribute driver_attr_##_name = \
37 __ATTR_IGNORE_LOCKDEP(_name, _mode, _show, _store)
38
39static int __must_check bus_rescan_devices_helper(struct device *dev,
40 void *data);
41
42static struct bus_type *bus_get(struct bus_type *bus)
43{
44 if (bus) {
45 kset_get(&bus->p->subsys);
46 return bus;
47 }
48 return NULL;
49}
50
51static void bus_put(struct bus_type *bus)
52{
53 if (bus)
54 kset_put(&bus->p->subsys);
55}
56
57static ssize_t drv_attr_show(struct kobject *kobj, struct attribute *attr,
58 char *buf)
59{
60 struct driver_attribute *drv_attr = to_drv_attr(attr);
61 struct driver_private *drv_priv = to_driver(kobj);
62 ssize_t ret = -EIO;
63
64 if (drv_attr->show)
65 ret = drv_attr->show(drv_priv->driver, buf);
66 return ret;
67}
68
69static ssize_t drv_attr_store(struct kobject *kobj, struct attribute *attr,
70 const char *buf, size_t count)
71{
72 struct driver_attribute *drv_attr = to_drv_attr(attr);
73 struct driver_private *drv_priv = to_driver(kobj);
74 ssize_t ret = -EIO;
75
76 if (drv_attr->store)
77 ret = drv_attr->store(drv_priv->driver, buf, count);
78 return ret;
79}
80
81static const struct sysfs_ops driver_sysfs_ops = {
82 .show = drv_attr_show,
83 .store = drv_attr_store,
84};
85
86static void driver_release(struct kobject *kobj)
87{
88 struct driver_private *drv_priv = to_driver(kobj);
89
90 pr_debug("driver: '%s': %s\n", kobject_name(kobj), __func__);
91 kfree(drv_priv);
92}
93
94static struct kobj_type driver_ktype = {
95 .sysfs_ops = &driver_sysfs_ops,
96 .release = driver_release,
97};
98
99
100
101
102static ssize_t bus_attr_show(struct kobject *kobj, struct attribute *attr,
103 char *buf)
104{
105 struct bus_attribute *bus_attr = to_bus_attr(attr);
106 struct subsys_private *subsys_priv = to_subsys_private(kobj);
107 ssize_t ret = 0;
108
109 if (bus_attr->show)
110 ret = bus_attr->show(subsys_priv->bus, buf);
111 return ret;
112}
113
114static ssize_t bus_attr_store(struct kobject *kobj, struct attribute *attr,
115 const char *buf, size_t count)
116{
117 struct bus_attribute *bus_attr = to_bus_attr(attr);
118 struct subsys_private *subsys_priv = to_subsys_private(kobj);
119 ssize_t ret = 0;
120
121 if (bus_attr->store)
122 ret = bus_attr->store(subsys_priv->bus, buf, count);
123 return ret;
124}
125
126static const struct sysfs_ops bus_sysfs_ops = {
127 .show = bus_attr_show,
128 .store = bus_attr_store,
129};
130
131int bus_create_file(struct bus_type *bus, struct bus_attribute *attr)
132{
133 int error;
134 if (bus_get(bus)) {
135 error = sysfs_create_file(&bus->p->subsys.kobj, &attr->attr);
136 bus_put(bus);
137 } else
138 error = -EINVAL;
139 return error;
140}
141EXPORT_SYMBOL_GPL(bus_create_file);
142
143void bus_remove_file(struct bus_type *bus, struct bus_attribute *attr)
144{
145 if (bus_get(bus)) {
146 sysfs_remove_file(&bus->p->subsys.kobj, &attr->attr);
147 bus_put(bus);
148 }
149}
150EXPORT_SYMBOL_GPL(bus_remove_file);
151
152static void bus_release(struct kobject *kobj)
153{
154 struct subsys_private *priv = to_subsys_private(kobj);
155 struct bus_type *bus = priv->bus;
156
157 kfree(priv);
158 bus->p = NULL;
159}
160
161static struct kobj_type bus_ktype = {
162 .sysfs_ops = &bus_sysfs_ops,
163 .release = bus_release,
164};
165
166static int bus_uevent_filter(struct kset *kset, struct kobject *kobj)
167{
168 struct kobj_type *ktype = get_ktype(kobj);
169
170 if (ktype == &bus_ktype)
171 return 1;
172 return 0;
173}
174
175static const struct kset_uevent_ops bus_uevent_ops = {
176 .filter = bus_uevent_filter,
177};
178
179static struct kset *bus_kset;
180
181
182static ssize_t unbind_store(struct device_driver *drv, const char *buf,
183 size_t count)
184{
185 struct bus_type *bus = bus_get(drv->bus);
186 struct device *dev;
187 int err = -ENODEV;
188
189 dev = bus_find_device_by_name(bus, NULL, buf);
190 if (dev && dev->driver == drv) {
191 device_driver_detach(dev);
192 err = count;
193 }
194 put_device(dev);
195 bus_put(bus);
196 return err;
197}
198static DRIVER_ATTR_IGNORE_LOCKDEP(unbind, S_IWUSR, NULL, unbind_store);
199
200
201
202
203
204
205static ssize_t bind_store(struct device_driver *drv, const char *buf,
206 size_t count)
207{
208 struct bus_type *bus = bus_get(drv->bus);
209 struct device *dev;
210 int err = -ENODEV;
211
212 dev = bus_find_device_by_name(bus, NULL, buf);
213 if (dev && dev->driver == NULL && driver_match_device(drv, dev)) {
214 err = device_driver_attach(drv, dev);
215
216 if (err > 0) {
217
218 err = count;
219 } else if (err == 0) {
220
221 err = -ENODEV;
222 }
223 }
224 put_device(dev);
225 bus_put(bus);
226 return err;
227}
228static DRIVER_ATTR_IGNORE_LOCKDEP(bind, S_IWUSR, NULL, bind_store);
229
230static ssize_t drivers_autoprobe_show(struct bus_type *bus, char *buf)
231{
232 return sysfs_emit(buf, "%d\n", bus->p->drivers_autoprobe);
233}
234
235static ssize_t drivers_autoprobe_store(struct bus_type *bus,
236 const char *buf, size_t count)
237{
238 if (buf[0] == '0')
239 bus->p->drivers_autoprobe = 0;
240 else
241 bus->p->drivers_autoprobe = 1;
242 return count;
243}
244
245static ssize_t drivers_probe_store(struct bus_type *bus,
246 const char *buf, size_t count)
247{
248 struct device *dev;
249 int err = -EINVAL;
250
251 dev = bus_find_device_by_name(bus, NULL, buf);
252 if (!dev)
253 return -ENODEV;
254 if (bus_rescan_devices_helper(dev, NULL) == 0)
255 err = count;
256 put_device(dev);
257 return err;
258}
259
260static struct device *next_device(struct klist_iter *i)
261{
262 struct klist_node *n = klist_next(i);
263 struct device *dev = NULL;
264 struct device_private *dev_prv;
265
266 if (n) {
267 dev_prv = to_device_private_bus(n);
268 dev = dev_prv->device;
269 }
270 return dev;
271}
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292int bus_for_each_dev(struct bus_type *bus, struct device *start,
293 void *data, int (*fn)(struct device *, void *))
294{
295 struct klist_iter i;
296 struct device *dev;
297 int error = 0;
298
299 if (!bus || !bus->p)
300 return -EINVAL;
301
302 klist_iter_init_node(&bus->p->klist_devices, &i,
303 (start ? &start->p->knode_bus : NULL));
304 while (!error && (dev = next_device(&i)))
305 error = fn(dev, data);
306 klist_iter_exit(&i);
307 return error;
308}
309EXPORT_SYMBOL_GPL(bus_for_each_dev);
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326struct device *bus_find_device(struct bus_type *bus,
327 struct device *start, const void *data,
328 int (*match)(struct device *dev, const void *data))
329{
330 struct klist_iter i;
331 struct device *dev;
332
333 if (!bus || !bus->p)
334 return NULL;
335
336 klist_iter_init_node(&bus->p->klist_devices, &i,
337 (start ? &start->p->knode_bus : NULL));
338 while ((dev = next_device(&i)))
339 if (match(dev, data) && get_device(dev))
340 break;
341 klist_iter_exit(&i);
342 return dev;
343}
344EXPORT_SYMBOL_GPL(bus_find_device);
345
346
347
348
349
350
351
352
353
354
355
356struct device *subsys_find_device_by_id(struct bus_type *subsys, unsigned int id,
357 struct device *hint)
358{
359 struct klist_iter i;
360 struct device *dev;
361
362 if (!subsys)
363 return NULL;
364
365 if (hint) {
366 klist_iter_init_node(&subsys->p->klist_devices, &i, &hint->p->knode_bus);
367 dev = next_device(&i);
368 if (dev && dev->id == id && get_device(dev)) {
369 klist_iter_exit(&i);
370 return dev;
371 }
372 klist_iter_exit(&i);
373 }
374
375 klist_iter_init_node(&subsys->p->klist_devices, &i, NULL);
376 while ((dev = next_device(&i))) {
377 if (dev->id == id && get_device(dev)) {
378 klist_iter_exit(&i);
379 return dev;
380 }
381 }
382 klist_iter_exit(&i);
383 return NULL;
384}
385EXPORT_SYMBOL_GPL(subsys_find_device_by_id);
386
387static struct device_driver *next_driver(struct klist_iter *i)
388{
389 struct klist_node *n = klist_next(i);
390 struct driver_private *drv_priv;
391
392 if (n) {
393 drv_priv = container_of(n, struct driver_private, knode_bus);
394 return drv_priv->driver;
395 }
396 return NULL;
397}
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418int bus_for_each_drv(struct bus_type *bus, struct device_driver *start,
419 void *data, int (*fn)(struct device_driver *, void *))
420{
421 struct klist_iter i;
422 struct device_driver *drv;
423 int error = 0;
424
425 if (!bus)
426 return -EINVAL;
427
428 klist_iter_init_node(&bus->p->klist_drivers, &i,
429 start ? &start->p->knode_bus : NULL);
430 while ((drv = next_driver(&i)) && !error)
431 error = fn(drv, data);
432 klist_iter_exit(&i);
433 return error;
434}
435EXPORT_SYMBOL_GPL(bus_for_each_drv);
436
437
438
439
440
441
442
443
444
445int bus_add_device(struct device *dev)
446{
447 struct bus_type *bus = bus_get(dev->bus);
448 int error = 0;
449
450 if (bus) {
451 pr_debug("bus: '%s': add device %s\n", bus->name, dev_name(dev));
452 error = device_add_groups(dev, bus->dev_groups);
453 if (error)
454 goto out_put;
455 error = sysfs_create_link(&bus->p->devices_kset->kobj,
456 &dev->kobj, dev_name(dev));
457 if (error)
458 goto out_groups;
459 error = sysfs_create_link(&dev->kobj,
460 &dev->bus->p->subsys.kobj, "subsystem");
461 if (error)
462 goto out_subsys;
463 klist_add_tail(&dev->p->knode_bus, &bus->p->klist_devices);
464 }
465 return 0;
466
467out_subsys:
468 sysfs_remove_link(&bus->p->devices_kset->kobj, dev_name(dev));
469out_groups:
470 device_remove_groups(dev, bus->dev_groups);
471out_put:
472 bus_put(dev->bus);
473 return error;
474}
475
476
477
478
479
480
481
482void bus_probe_device(struct device *dev)
483{
484 struct bus_type *bus = dev->bus;
485 struct subsys_interface *sif;
486
487 if (!bus)
488 return;
489
490 if (bus->p->drivers_autoprobe)
491 device_initial_probe(dev);
492
493 mutex_lock(&bus->p->mutex);
494 list_for_each_entry(sif, &bus->p->interfaces, node)
495 if (sif->add_dev)
496 sif->add_dev(dev, sif);
497 mutex_unlock(&bus->p->mutex);
498}
499
500
501
502
503
504
505
506
507
508
509
510void bus_remove_device(struct device *dev)
511{
512 struct bus_type *bus = dev->bus;
513 struct subsys_interface *sif;
514
515 if (!bus)
516 return;
517
518 mutex_lock(&bus->p->mutex);
519 list_for_each_entry(sif, &bus->p->interfaces, node)
520 if (sif->remove_dev)
521 sif->remove_dev(dev, sif);
522 mutex_unlock(&bus->p->mutex);
523
524 sysfs_remove_link(&dev->kobj, "subsystem");
525 sysfs_remove_link(&dev->bus->p->devices_kset->kobj,
526 dev_name(dev));
527 device_remove_groups(dev, dev->bus->dev_groups);
528 if (klist_node_attached(&dev->p->knode_bus))
529 klist_del(&dev->p->knode_bus);
530
531 pr_debug("bus: '%s': remove device %s\n",
532 dev->bus->name, dev_name(dev));
533 device_release_driver(dev);
534 bus_put(dev->bus);
535}
536
537static int __must_check add_bind_files(struct device_driver *drv)
538{
539 int ret;
540
541 ret = driver_create_file(drv, &driver_attr_unbind);
542 if (ret == 0) {
543 ret = driver_create_file(drv, &driver_attr_bind);
544 if (ret)
545 driver_remove_file(drv, &driver_attr_unbind);
546 }
547 return ret;
548}
549
550static void remove_bind_files(struct device_driver *drv)
551{
552 driver_remove_file(drv, &driver_attr_bind);
553 driver_remove_file(drv, &driver_attr_unbind);
554}
555
556static BUS_ATTR_WO(drivers_probe);
557static BUS_ATTR_RW(drivers_autoprobe);
558
559static int add_probe_files(struct bus_type *bus)
560{
561 int retval;
562
563 retval = bus_create_file(bus, &bus_attr_drivers_probe);
564 if (retval)
565 goto out;
566
567 retval = bus_create_file(bus, &bus_attr_drivers_autoprobe);
568 if (retval)
569 bus_remove_file(bus, &bus_attr_drivers_probe);
570out:
571 return retval;
572}
573
574static void remove_probe_files(struct bus_type *bus)
575{
576 bus_remove_file(bus, &bus_attr_drivers_autoprobe);
577 bus_remove_file(bus, &bus_attr_drivers_probe);
578}
579
580static ssize_t uevent_store(struct device_driver *drv, const char *buf,
581 size_t count)
582{
583 int rc;
584
585 rc = kobject_synth_uevent(&drv->p->kobj, buf, count);
586 return rc ? rc : count;
587}
588static DRIVER_ATTR_WO(uevent);
589
590
591
592
593
594int bus_add_driver(struct device_driver *drv)
595{
596 struct bus_type *bus;
597 struct driver_private *priv;
598 int error = 0;
599
600 bus = bus_get(drv->bus);
601 if (!bus)
602 return -EINVAL;
603
604 pr_debug("bus: '%s': add driver %s\n", bus->name, drv->name);
605
606 priv = kzalloc(sizeof(*priv), GFP_KERNEL);
607 if (!priv) {
608 error = -ENOMEM;
609 goto out_put_bus;
610 }
611 klist_init(&priv->klist_devices, NULL, NULL);
612 priv->driver = drv;
613 drv->p = priv;
614 priv->kobj.kset = bus->p->drivers_kset;
615 error = kobject_init_and_add(&priv->kobj, &driver_ktype, NULL,
616 "%s", drv->name);
617 if (error)
618 goto out_unregister;
619
620 klist_add_tail(&priv->knode_bus, &bus->p->klist_drivers);
621 if (drv->bus->p->drivers_autoprobe) {
622 error = driver_attach(drv);
623 if (error)
624 goto out_unregister;
625 }
626 module_add_driver(drv->owner, drv);
627
628 error = driver_create_file(drv, &driver_attr_uevent);
629 if (error) {
630 printk(KERN_ERR "%s: uevent attr (%s) failed\n",
631 __func__, drv->name);
632 }
633 error = driver_add_groups(drv, bus->drv_groups);
634 if (error) {
635
636 printk(KERN_ERR "%s: driver_create_groups(%s) failed\n",
637 __func__, drv->name);
638 }
639
640 if (!drv->suppress_bind_attrs) {
641 error = add_bind_files(drv);
642 if (error) {
643
644 printk(KERN_ERR "%s: add_bind_files(%s) failed\n",
645 __func__, drv->name);
646 }
647 }
648
649 return 0;
650
651out_unregister:
652 kobject_put(&priv->kobj);
653
654 drv->p = NULL;
655out_put_bus:
656 bus_put(bus);
657 return error;
658}
659
660
661
662
663
664
665
666
667
668void bus_remove_driver(struct device_driver *drv)
669{
670 if (!drv->bus)
671 return;
672
673 if (!drv->suppress_bind_attrs)
674 remove_bind_files(drv);
675 driver_remove_groups(drv, drv->bus->drv_groups);
676 driver_remove_file(drv, &driver_attr_uevent);
677 klist_remove(&drv->p->knode_bus);
678 pr_debug("bus: '%s': remove driver %s\n", drv->bus->name, drv->name);
679 driver_detach(drv);
680 module_remove_driver(drv);
681 kobject_put(&drv->p->kobj);
682 bus_put(drv->bus);
683}
684
685
686static int __must_check bus_rescan_devices_helper(struct device *dev,
687 void *data)
688{
689 int ret = 0;
690
691 if (!dev->driver) {
692 if (dev->parent && dev->bus->need_parent_lock)
693 device_lock(dev->parent);
694 ret = device_attach(dev);
695 if (dev->parent && dev->bus->need_parent_lock)
696 device_unlock(dev->parent);
697 }
698 return ret < 0 ? ret : 0;
699}
700
701
702
703
704
705
706
707
708
709int bus_rescan_devices(struct bus_type *bus)
710{
711 return bus_for_each_dev(bus, NULL, NULL, bus_rescan_devices_helper);
712}
713EXPORT_SYMBOL_GPL(bus_rescan_devices);
714
715
716
717
718
719
720
721
722
723
724int device_reprobe(struct device *dev)
725{
726 if (dev->driver)
727 device_driver_detach(dev);
728 return bus_rescan_devices_helper(dev, NULL);
729}
730EXPORT_SYMBOL_GPL(device_reprobe);
731
732
733
734
735
736
737
738
739
740
741#if 0
742struct bus_type *find_bus(char *name)
743{
744 struct kobject *k = kset_find_obj(bus_kset, name);
745 return k ? to_bus(k) : NULL;
746}
747#endif
748
749static int bus_add_groups(struct bus_type *bus,
750 const struct attribute_group **groups)
751{
752 return sysfs_create_groups(&bus->p->subsys.kobj, groups);
753}
754
755static void bus_remove_groups(struct bus_type *bus,
756 const struct attribute_group **groups)
757{
758 sysfs_remove_groups(&bus->p->subsys.kobj, groups);
759}
760
761static void klist_devices_get(struct klist_node *n)
762{
763 struct device_private *dev_prv = to_device_private_bus(n);
764 struct device *dev = dev_prv->device;
765
766 get_device(dev);
767}
768
769static void klist_devices_put(struct klist_node *n)
770{
771 struct device_private *dev_prv = to_device_private_bus(n);
772 struct device *dev = dev_prv->device;
773
774 put_device(dev);
775}
776
777static ssize_t bus_uevent_store(struct bus_type *bus,
778 const char *buf, size_t count)
779{
780 int rc;
781
782 rc = kobject_synth_uevent(&bus->p->subsys.kobj, buf, count);
783 return rc ? rc : count;
784}
785
786
787
788
789
790
791static struct bus_attribute bus_attr_uevent = __ATTR(uevent, S_IWUSR, NULL,
792 bus_uevent_store);
793
794
795
796
797
798
799
800
801
802int bus_register(struct bus_type *bus)
803{
804 int retval;
805 struct subsys_private *priv;
806 struct lock_class_key *key = &bus->lock_key;
807
808 priv = kzalloc(sizeof(struct subsys_private), GFP_KERNEL);
809 if (!priv)
810 return -ENOMEM;
811
812 priv->bus = bus;
813 bus->p = priv;
814
815 BLOCKING_INIT_NOTIFIER_HEAD(&priv->bus_notifier);
816
817 retval = kobject_set_name(&priv->subsys.kobj, "%s", bus->name);
818 if (retval)
819 goto out;
820
821 priv->subsys.kobj.kset = bus_kset;
822 priv->subsys.kobj.ktype = &bus_ktype;
823 priv->drivers_autoprobe = 1;
824
825 retval = kset_register(&priv->subsys);
826 if (retval)
827 goto out;
828
829 retval = bus_create_file(bus, &bus_attr_uevent);
830 if (retval)
831 goto bus_uevent_fail;
832
833 priv->devices_kset = kset_create_and_add("devices", NULL,
834 &priv->subsys.kobj);
835 if (!priv->devices_kset) {
836 retval = -ENOMEM;
837 goto bus_devices_fail;
838 }
839
840 priv->drivers_kset = kset_create_and_add("drivers", NULL,
841 &priv->subsys.kobj);
842 if (!priv->drivers_kset) {
843 retval = -ENOMEM;
844 goto bus_drivers_fail;
845 }
846
847 INIT_LIST_HEAD(&priv->interfaces);
848 __mutex_init(&priv->mutex, "subsys mutex", key);
849 klist_init(&priv->klist_devices, klist_devices_get, klist_devices_put);
850 klist_init(&priv->klist_drivers, NULL, NULL);
851
852 retval = add_probe_files(bus);
853 if (retval)
854 goto bus_probe_files_fail;
855
856 retval = bus_add_groups(bus, bus->bus_groups);
857 if (retval)
858 goto bus_groups_fail;
859
860 pr_debug("bus: '%s': registered\n", bus->name);
861 return 0;
862
863bus_groups_fail:
864 remove_probe_files(bus);
865bus_probe_files_fail:
866 kset_unregister(bus->p->drivers_kset);
867bus_drivers_fail:
868 kset_unregister(bus->p->devices_kset);
869bus_devices_fail:
870 bus_remove_file(bus, &bus_attr_uevent);
871bus_uevent_fail:
872 kset_unregister(&bus->p->subsys);
873out:
874 kfree(bus->p);
875 bus->p = NULL;
876 return retval;
877}
878EXPORT_SYMBOL_GPL(bus_register);
879
880
881
882
883
884
885
886
887void bus_unregister(struct bus_type *bus)
888{
889 pr_debug("bus: '%s': unregistering\n", bus->name);
890 if (bus->dev_root)
891 device_unregister(bus->dev_root);
892 bus_remove_groups(bus, bus->bus_groups);
893 remove_probe_files(bus);
894 kset_unregister(bus->p->drivers_kset);
895 kset_unregister(bus->p->devices_kset);
896 bus_remove_file(bus, &bus_attr_uevent);
897 kset_unregister(&bus->p->subsys);
898}
899EXPORT_SYMBOL_GPL(bus_unregister);
900
901int bus_register_notifier(struct bus_type *bus, struct notifier_block *nb)
902{
903 return blocking_notifier_chain_register(&bus->p->bus_notifier, nb);
904}
905EXPORT_SYMBOL_GPL(bus_register_notifier);
906
907int bus_unregister_notifier(struct bus_type *bus, struct notifier_block *nb)
908{
909 return blocking_notifier_chain_unregister(&bus->p->bus_notifier, nb);
910}
911EXPORT_SYMBOL_GPL(bus_unregister_notifier);
912
913struct kset *bus_get_kset(struct bus_type *bus)
914{
915 return &bus->p->subsys;
916}
917EXPORT_SYMBOL_GPL(bus_get_kset);
918
919struct klist *bus_get_device_klist(struct bus_type *bus)
920{
921 return &bus->p->klist_devices;
922}
923EXPORT_SYMBOL_GPL(bus_get_device_klist);
924
925
926
927
928
929
930
931
932static void device_insertion_sort_klist(struct device *a, struct list_head *list,
933 int (*compare)(const struct device *a,
934 const struct device *b))
935{
936 struct klist_node *n;
937 struct device_private *dev_prv;
938 struct device *b;
939
940 list_for_each_entry(n, list, n_node) {
941 dev_prv = to_device_private_bus(n);
942 b = dev_prv->device;
943 if (compare(a, b) <= 0) {
944 list_move_tail(&a->p->knode_bus.n_node,
945 &b->p->knode_bus.n_node);
946 return;
947 }
948 }
949 list_move_tail(&a->p->knode_bus.n_node, list);
950}
951
952void bus_sort_breadthfirst(struct bus_type *bus,
953 int (*compare)(const struct device *a,
954 const struct device *b))
955{
956 LIST_HEAD(sorted_devices);
957 struct klist_node *n, *tmp;
958 struct device_private *dev_prv;
959 struct device *dev;
960 struct klist *device_klist;
961
962 device_klist = bus_get_device_klist(bus);
963
964 spin_lock(&device_klist->k_lock);
965 list_for_each_entry_safe(n, tmp, &device_klist->k_list, n_node) {
966 dev_prv = to_device_private_bus(n);
967 dev = dev_prv->device;
968 device_insertion_sort_klist(dev, &sorted_devices, compare);
969 }
970 list_splice(&sorted_devices, &device_klist->k_list);
971 spin_unlock(&device_klist->k_lock);
972}
973EXPORT_SYMBOL_GPL(bus_sort_breadthfirst);
974
975
976
977
978
979
980
981
982
983
984
985
986
987void subsys_dev_iter_init(struct subsys_dev_iter *iter, struct bus_type *subsys,
988 struct device *start, const struct device_type *type)
989{
990 struct klist_node *start_knode = NULL;
991
992 if (start)
993 start_knode = &start->p->knode_bus;
994 klist_iter_init_node(&subsys->p->klist_devices, &iter->ki, start_knode);
995 iter->type = type;
996}
997EXPORT_SYMBOL_GPL(subsys_dev_iter_init);
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011struct device *subsys_dev_iter_next(struct subsys_dev_iter *iter)
1012{
1013 struct klist_node *knode;
1014 struct device *dev;
1015
1016 for (;;) {
1017 knode = klist_next(&iter->ki);
1018 if (!knode)
1019 return NULL;
1020 dev = to_device_private_bus(knode)->device;
1021 if (!iter->type || iter->type == dev->type)
1022 return dev;
1023 }
1024}
1025EXPORT_SYMBOL_GPL(subsys_dev_iter_next);
1026
1027
1028
1029
1030
1031
1032
1033
1034void subsys_dev_iter_exit(struct subsys_dev_iter *iter)
1035{
1036 klist_iter_exit(&iter->ki);
1037}
1038EXPORT_SYMBOL_GPL(subsys_dev_iter_exit);
1039
1040int subsys_interface_register(struct subsys_interface *sif)
1041{
1042 struct bus_type *subsys;
1043 struct subsys_dev_iter iter;
1044 struct device *dev;
1045
1046 if (!sif || !sif->subsys)
1047 return -ENODEV;
1048
1049 subsys = bus_get(sif->subsys);
1050 if (!subsys)
1051 return -EINVAL;
1052
1053 mutex_lock(&subsys->p->mutex);
1054 list_add_tail(&sif->node, &subsys->p->interfaces);
1055 if (sif->add_dev) {
1056 subsys_dev_iter_init(&iter, subsys, NULL, NULL);
1057 while ((dev = subsys_dev_iter_next(&iter)))
1058 sif->add_dev(dev, sif);
1059 subsys_dev_iter_exit(&iter);
1060 }
1061 mutex_unlock(&subsys->p->mutex);
1062
1063 return 0;
1064}
1065EXPORT_SYMBOL_GPL(subsys_interface_register);
1066
1067void subsys_interface_unregister(struct subsys_interface *sif)
1068{
1069 struct bus_type *subsys;
1070 struct subsys_dev_iter iter;
1071 struct device *dev;
1072
1073 if (!sif || !sif->subsys)
1074 return;
1075
1076 subsys = sif->subsys;
1077
1078 mutex_lock(&subsys->p->mutex);
1079 list_del_init(&sif->node);
1080 if (sif->remove_dev) {
1081 subsys_dev_iter_init(&iter, subsys, NULL, NULL);
1082 while ((dev = subsys_dev_iter_next(&iter)))
1083 sif->remove_dev(dev, sif);
1084 subsys_dev_iter_exit(&iter);
1085 }
1086 mutex_unlock(&subsys->p->mutex);
1087
1088 bus_put(subsys);
1089}
1090EXPORT_SYMBOL_GPL(subsys_interface_unregister);
1091
1092static void system_root_device_release(struct device *dev)
1093{
1094 kfree(dev);
1095}
1096
1097static int subsys_register(struct bus_type *subsys,
1098 const struct attribute_group **groups,
1099 struct kobject *parent_of_root)
1100{
1101 struct device *dev;
1102 int err;
1103
1104 err = bus_register(subsys);
1105 if (err < 0)
1106 return err;
1107
1108 dev = kzalloc(sizeof(struct device), GFP_KERNEL);
1109 if (!dev) {
1110 err = -ENOMEM;
1111 goto err_dev;
1112 }
1113
1114 err = dev_set_name(dev, "%s", subsys->name);
1115 if (err < 0)
1116 goto err_name;
1117
1118 dev->kobj.parent = parent_of_root;
1119 dev->groups = groups;
1120 dev->release = system_root_device_release;
1121
1122 err = device_register(dev);
1123 if (err < 0)
1124 goto err_dev_reg;
1125
1126 subsys->dev_root = dev;
1127 return 0;
1128
1129err_dev_reg:
1130 put_device(dev);
1131 dev = NULL;
1132err_name:
1133 kfree(dev);
1134err_dev:
1135 bus_unregister(subsys);
1136 return err;
1137}
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157int subsys_system_register(struct bus_type *subsys,
1158 const struct attribute_group **groups)
1159{
1160 return subsys_register(subsys, groups, &system_kset->kobj);
1161}
1162EXPORT_SYMBOL_GPL(subsys_system_register);
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
1173
1174
1175int subsys_virtual_register(struct bus_type *subsys,
1176 const struct attribute_group **groups)
1177{
1178 struct kobject *virtual_dir;
1179
1180 virtual_dir = virtual_device_parent(NULL);
1181 if (!virtual_dir)
1182 return -ENOMEM;
1183
1184 return subsys_register(subsys, groups, virtual_dir);
1185}
1186EXPORT_SYMBOL_GPL(subsys_virtual_register);
1187
1188int __init buses_init(void)
1189{
1190 bus_kset = kset_create_and_add("bus", &bus_uevent_ops, NULL);
1191 if (!bus_kset)
1192 return -ENOMEM;
1193
1194 system_kset = kset_create_and_add("system", NULL, &devices_kset->kobj);
1195 if (!system_kset)
1196 return -ENOMEM;
1197
1198 return 0;
1199}
1200