sysfs-common.c 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Common Code for DAMON Sysfs Interface
  4. *
  5. * Author: SeongJae Park <sj@kernel.org>
  6. */
  7. #include <linux/slab.h>
  8. #include "sysfs-common.h"
  9. DEFINE_MUTEX(damon_sysfs_lock);
  10. /*
  11. * unsigned long range directory
  12. */
  13. struct damon_sysfs_ul_range *damon_sysfs_ul_range_alloc(
  14. unsigned long min,
  15. unsigned long max)
  16. {
  17. struct damon_sysfs_ul_range *range = kmalloc_obj(*range);
  18. if (!range)
  19. return NULL;
  20. range->kobj = (struct kobject){};
  21. range->min = min;
  22. range->max = max;
  23. return range;
  24. }
  25. static ssize_t min_show(struct kobject *kobj, struct kobj_attribute *attr,
  26. char *buf)
  27. {
  28. struct damon_sysfs_ul_range *range = container_of(kobj,
  29. struct damon_sysfs_ul_range, kobj);
  30. return sysfs_emit(buf, "%lu\n", range->min);
  31. }
  32. static ssize_t min_store(struct kobject *kobj, struct kobj_attribute *attr,
  33. const char *buf, size_t count)
  34. {
  35. struct damon_sysfs_ul_range *range = container_of(kobj,
  36. struct damon_sysfs_ul_range, kobj);
  37. unsigned long min;
  38. int err;
  39. err = kstrtoul(buf, 0, &min);
  40. if (err)
  41. return err;
  42. range->min = min;
  43. return count;
  44. }
  45. static ssize_t max_show(struct kobject *kobj, struct kobj_attribute *attr,
  46. char *buf)
  47. {
  48. struct damon_sysfs_ul_range *range = container_of(kobj,
  49. struct damon_sysfs_ul_range, kobj);
  50. return sysfs_emit(buf, "%lu\n", range->max);
  51. }
  52. static ssize_t max_store(struct kobject *kobj, struct kobj_attribute *attr,
  53. const char *buf, size_t count)
  54. {
  55. struct damon_sysfs_ul_range *range = container_of(kobj,
  56. struct damon_sysfs_ul_range, kobj);
  57. unsigned long max;
  58. int err;
  59. err = kstrtoul(buf, 0, &max);
  60. if (err)
  61. return err;
  62. range->max = max;
  63. return count;
  64. }
  65. void damon_sysfs_ul_range_release(struct kobject *kobj)
  66. {
  67. kfree(container_of(kobj, struct damon_sysfs_ul_range, kobj));
  68. }
  69. static struct kobj_attribute damon_sysfs_ul_range_min_attr =
  70. __ATTR_RW_MODE(min, 0600);
  71. static struct kobj_attribute damon_sysfs_ul_range_max_attr =
  72. __ATTR_RW_MODE(max, 0600);
  73. static struct attribute *damon_sysfs_ul_range_attrs[] = {
  74. &damon_sysfs_ul_range_min_attr.attr,
  75. &damon_sysfs_ul_range_max_attr.attr,
  76. NULL,
  77. };
  78. ATTRIBUTE_GROUPS(damon_sysfs_ul_range);
  79. const struct kobj_type damon_sysfs_ul_range_ktype = {
  80. .release = damon_sysfs_ul_range_release,
  81. .sysfs_ops = &kobj_sysfs_ops,
  82. .default_groups = damon_sysfs_ul_range_groups,
  83. };