module.c 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * module.c - module sysfs fun for drivers
  4. *
  5. * This file is released under the GPLv2
  6. *
  7. */
  8. #include <linux/device.h>
  9. #include <linux/module.h>
  10. #include <linux/errno.h>
  11. #include <linux/slab.h>
  12. #include <linux/string.h>
  13. #include "base.h"
  14. static char *make_driver_name(struct device_driver *drv)
  15. {
  16. char *driver_name;
  17. driver_name = kasprintf(GFP_KERNEL, "%s:%s", drv->bus->name, drv->name);
  18. if (!driver_name)
  19. return NULL;
  20. return driver_name;
  21. }
  22. static void module_create_drivers_dir(struct module_kobject *mk)
  23. {
  24. static DEFINE_MUTEX(drivers_dir_mutex);
  25. mutex_lock(&drivers_dir_mutex);
  26. if (mk && !mk->drivers_dir)
  27. mk->drivers_dir = kobject_create_and_add("drivers", &mk->kobj);
  28. mutex_unlock(&drivers_dir_mutex);
  29. }
  30. void module_add_driver(struct module *mod, struct device_driver *drv)
  31. {
  32. char *driver_name;
  33. int no_warn;
  34. struct module_kobject *mk = NULL;
  35. if (!drv)
  36. return;
  37. if (mod)
  38. mk = &mod->mkobj;
  39. else if (drv->mod_name) {
  40. struct kobject *mkobj;
  41. /* Lookup built-in module entry in /sys/modules */
  42. mkobj = kset_find_obj(module_kset, drv->mod_name);
  43. if (mkobj) {
  44. mk = container_of(mkobj, struct module_kobject, kobj);
  45. /* remember our module structure */
  46. drv->p->mkobj = mk;
  47. /* kset_find_obj took a reference */
  48. kobject_put(mkobj);
  49. }
  50. }
  51. if (!mk)
  52. return;
  53. /* Don't check return codes; these calls are idempotent */
  54. no_warn = sysfs_create_link(&drv->p->kobj, &mk->kobj, "module");
  55. driver_name = make_driver_name(drv);
  56. if (driver_name) {
  57. module_create_drivers_dir(mk);
  58. no_warn = sysfs_create_link(mk->drivers_dir, &drv->p->kobj,
  59. driver_name);
  60. kfree(driver_name);
  61. }
  62. }
  63. void module_remove_driver(struct device_driver *drv)
  64. {
  65. struct module_kobject *mk = NULL;
  66. char *driver_name;
  67. if (!drv)
  68. return;
  69. sysfs_remove_link(&drv->p->kobj, "module");
  70. if (drv->owner)
  71. mk = &drv->owner->mkobj;
  72. else if (drv->p->mkobj)
  73. mk = drv->p->mkobj;
  74. if (mk && mk->drivers_dir) {
  75. driver_name = make_driver_name(drv);
  76. if (driver_name) {
  77. sysfs_remove_link(mk->drivers_dir, driver_name);
  78. kfree(driver_name);
  79. }
  80. }
  81. }