sysfs.h 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. #ifndef _BTRFS_SYSFS_H_
  3. #define _BTRFS_SYSFS_H_
  4. /*
  5. * Data exported through sysfs
  6. */
  7. extern u64 btrfs_debugfs_test;
  8. enum btrfs_feature_set {
  9. FEAT_COMPAT,
  10. FEAT_COMPAT_RO,
  11. FEAT_INCOMPAT,
  12. FEAT_MAX
  13. };
  14. #define __INIT_KOBJ_ATTR(_name, _mode, _show, _store) \
  15. { \
  16. .attr = { .name = __stringify(_name), .mode = _mode }, \
  17. .show = _show, \
  18. .store = _store, \
  19. }
  20. #define BTRFS_ATTR_RW(_prefix, _name, _show, _store) \
  21. static struct kobj_attribute btrfs_attr_##_prefix##_##_name = \
  22. __INIT_KOBJ_ATTR(_name, 0644, _show, _store)
  23. #define BTRFS_ATTR(_prefix, _name, _show) \
  24. static struct kobj_attribute btrfs_attr_##_prefix##_##_name = \
  25. __INIT_KOBJ_ATTR(_name, 0444, _show, NULL)
  26. #define BTRFS_ATTR_PTR(_prefix, _name) \
  27. (&btrfs_attr_##_prefix##_##_name.attr)
  28. struct btrfs_feature_attr {
  29. struct kobj_attribute kobj_attr;
  30. enum btrfs_feature_set feature_set;
  31. u64 feature_bit;
  32. };
  33. #define BTRFS_FEAT_ATTR(_name, _feature_set, _feature_prefix, _feature_bit) \
  34. static struct btrfs_feature_attr btrfs_attr_features_##_name = { \
  35. .kobj_attr = __INIT_KOBJ_ATTR(_name, S_IRUGO, \
  36. btrfs_feature_attr_show, \
  37. btrfs_feature_attr_store), \
  38. .feature_set = _feature_set, \
  39. .feature_bit = _feature_prefix ##_## _feature_bit, \
  40. }
  41. #define BTRFS_FEAT_ATTR_PTR(_name) \
  42. (&btrfs_attr_features_##_name.kobj_attr.attr)
  43. #define BTRFS_FEAT_ATTR_COMPAT(name, feature) \
  44. BTRFS_FEAT_ATTR(name, FEAT_COMPAT, BTRFS_FEATURE_COMPAT, feature)
  45. #define BTRFS_FEAT_ATTR_COMPAT_RO(name, feature) \
  46. BTRFS_FEAT_ATTR(name, FEAT_COMPAT_RO, BTRFS_FEATURE_COMPAT_RO, feature)
  47. #define BTRFS_FEAT_ATTR_INCOMPAT(name, feature) \
  48. BTRFS_FEAT_ATTR(name, FEAT_INCOMPAT, BTRFS_FEATURE_INCOMPAT, feature)
  49. /* convert from attribute */
  50. static inline struct btrfs_feature_attr *
  51. to_btrfs_feature_attr(struct kobj_attribute *a)
  52. {
  53. return container_of(a, struct btrfs_feature_attr, kobj_attr);
  54. }
  55. static inline struct kobj_attribute *attr_to_btrfs_attr(struct attribute *attr)
  56. {
  57. return container_of(attr, struct kobj_attribute, attr);
  58. }
  59. static inline struct btrfs_feature_attr *
  60. attr_to_btrfs_feature_attr(struct attribute *attr)
  61. {
  62. return to_btrfs_feature_attr(attr_to_btrfs_attr(attr));
  63. }
  64. char *btrfs_printable_features(enum btrfs_feature_set set, u64 flags);
  65. extern const char * const btrfs_feature_set_names[3];
  66. extern struct kobj_type space_info_ktype;
  67. extern struct kobj_type btrfs_raid_ktype;
  68. int btrfs_sysfs_add_device_link(struct btrfs_fs_devices *fs_devices,
  69. struct btrfs_device *one_device);
  70. int btrfs_sysfs_rm_device_link(struct btrfs_fs_devices *fs_devices,
  71. struct btrfs_device *one_device);
  72. int btrfs_sysfs_add_fsid(struct btrfs_fs_devices *fs_devs,
  73. struct kobject *parent);
  74. int btrfs_sysfs_add_device(struct btrfs_fs_devices *fs_devs);
  75. void btrfs_sysfs_remove_fsid(struct btrfs_fs_devices *fs_devs);
  76. void btrfs_sysfs_feature_update(struct btrfs_fs_info *fs_info,
  77. u64 bit, enum btrfs_feature_set set);
  78. #endif /* _BTRFS_SYSFS_H_ */