sysfs.h 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  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 = 0,
  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[FEAT_MAX];
  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