module.c 2.0 KB

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