group.c 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. /*
  2. * fs/sysfs/group.c - Operations for adding/removing multiple files at once.
  3. *
  4. * Copyright (c) 2003 Patrick Mochel
  5. * Copyright (c) 2003 Open Source Development Lab
  6. *
  7. * This file is released undert the GPL v2.
  8. *
  9. */
  10. #include <linux/kobject.h>
  11. #include <linux/module.h>
  12. #include <linux/dcache.h>
  13. #include <linux/namei.h>
  14. #include <linux/err.h>
  15. #include <asm/semaphore.h>
  16. #include "sysfs.h"
  17. static void remove_files(struct dentry * dir,
  18. const struct attribute_group * grp)
  19. {
  20. struct attribute *const* attr;
  21. for (attr = grp->attrs; *attr; attr++)
  22. sysfs_hash_and_remove(dir,(*attr)->name);
  23. }
  24. static int create_files(struct dentry * dir,
  25. const struct attribute_group * grp)
  26. {
  27. struct attribute *const* attr;
  28. int error = 0;
  29. for (attr = grp->attrs; *attr && !error; attr++) {
  30. error = sysfs_add_file(dir, *attr, SYSFS_KOBJ_ATTR);
  31. }
  32. if (error)
  33. remove_files(dir,grp);
  34. return error;
  35. }
  36. int sysfs_create_group(struct kobject * kobj,
  37. const struct attribute_group * grp)
  38. {
  39. struct dentry * dir;
  40. int error;
  41. BUG_ON(!kobj || !kobj->dentry);
  42. if (grp->name) {
  43. error = sysfs_create_subdir(kobj,grp->name,&dir);
  44. if (error)
  45. return error;
  46. } else
  47. dir = kobj->dentry;
  48. dir = dget(dir);
  49. if ((error = create_files(dir,grp))) {
  50. if (grp->name)
  51. sysfs_remove_subdir(dir);
  52. }
  53. dput(dir);
  54. return error;
  55. }
  56. void sysfs_remove_group(struct kobject * kobj,
  57. const struct attribute_group * grp)
  58. {
  59. struct dentry * dir;
  60. if (grp->name)
  61. dir = lookup_one_len(grp->name, kobj->dentry,
  62. strlen(grp->name));
  63. else
  64. dir = dget(kobj->dentry);
  65. remove_files(dir,grp);
  66. if (grp->name)
  67. sysfs_remove_subdir(dir);
  68. /* release the ref. taken in this routine */
  69. dput(dir);
  70. }
  71. EXPORT_SYMBOL_GPL(sysfs_create_group);
  72. EXPORT_SYMBOL_GPL(sysfs_remove_group);