blob: 031697358b6e63a0c0626559cd88ef37598dc57b [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
David Sterba9888c342018-04-03 19:16:55 +02002
3#ifndef BTRFS_SYSFS_H
4#define BTRFS_SYSFS_H
Jeff Mahoney079b72b2013-11-01 13:06:57 -04005
6enum btrfs_feature_set {
David Sterbabbe339c2018-11-27 15:25:13 +01007 FEAT_COMPAT,
Jeff Mahoney079b72b2013-11-01 13:06:57 -04008 FEAT_COMPAT_RO,
9 FEAT_INCOMPAT,
10 FEAT_MAX
11};
12
13#define __INIT_KOBJ_ATTR(_name, _mode, _show, _store) \
14{ \
15 .attr = { .name = __stringify(_name), .mode = _mode }, \
16 .show = _show, \
17 .store = _store, \
18}
19
Hans van Kranenburga969f4c2017-10-08 22:30:58 +020020#define BTRFS_ATTR_RW(_prefix, _name, _show, _store) \
21 static struct kobj_attribute btrfs_attr_##_prefix##_##_name = \
Anand Jain20ee0822014-07-30 20:04:09 +080022 __INIT_KOBJ_ATTR(_name, 0644, _show, _store)
Anand Jain98b3d382014-07-30 20:04:08 +080023
Hans van Kranenburga969f4c2017-10-08 22:30:58 +020024#define BTRFS_ATTR(_prefix, _name, _show) \
25 static struct kobj_attribute btrfs_attr_##_prefix##_##_name = \
Anand Jain20ee0822014-07-30 20:04:09 +080026 __INIT_KOBJ_ATTR(_name, 0444, _show, NULL)
Anand Jain98b3d382014-07-30 20:04:08 +080027
Hans van Kranenburga969f4c2017-10-08 22:30:58 +020028#define BTRFS_ATTR_PTR(_prefix, _name) \
29 (&btrfs_attr_##_prefix##_##_name.attr)
Jeff Mahoney6ab0a202013-11-01 13:07:04 -040030
31
Jeff Mahoney079b72b2013-11-01 13:06:57 -040032struct btrfs_feature_attr {
33 struct kobj_attribute kobj_attr;
34 enum btrfs_feature_set feature_set;
35 u64 feature_bit;
36};
37
David Sterba89439102019-08-01 17:34:41 +020038/* For raid type sysfs entries */
39struct raid_kobject {
40 u64 flags;
41 struct kobject kobj;
42};
43
Hans van Kranenburga969f4c2017-10-08 22:30:58 +020044#define BTRFS_FEAT_ATTR(_name, _feature_set, _feature_prefix, _feature_bit) \
45static struct btrfs_feature_attr btrfs_attr_features_##_name = { \
Jeff Mahoney079b72b2013-11-01 13:06:57 -040046 .kobj_attr = __INIT_KOBJ_ATTR(_name, S_IRUGO, \
Jeff Mahoneyba631942013-11-01 13:07:01 -040047 btrfs_feature_attr_show, \
48 btrfs_feature_attr_store), \
Jeff Mahoney079b72b2013-11-01 13:06:57 -040049 .feature_set = _feature_set, \
Hans van Kranenburga969f4c2017-10-08 22:30:58 +020050 .feature_bit = _feature_prefix ##_## _feature_bit, \
Jeff Mahoney079b72b2013-11-01 13:06:57 -040051}
Hans van Kranenburga969f4c2017-10-08 22:30:58 +020052#define BTRFS_FEAT_ATTR_PTR(_name) \
53 (&btrfs_attr_features_##_name.kobj_attr.attr)
Jeff Mahoney079b72b2013-11-01 13:06:57 -040054
55#define BTRFS_FEAT_ATTR_COMPAT(name, feature) \
56 BTRFS_FEAT_ATTR(name, FEAT_COMPAT, BTRFS_FEATURE_COMPAT, feature)
57#define BTRFS_FEAT_ATTR_COMPAT_RO(name, feature) \
David Sterbaba2d0842016-01-20 19:07:04 +010058 BTRFS_FEAT_ATTR(name, FEAT_COMPAT_RO, BTRFS_FEATURE_COMPAT_RO, feature)
Jeff Mahoney079b72b2013-11-01 13:06:57 -040059#define BTRFS_FEAT_ATTR_INCOMPAT(name, feature) \
60 BTRFS_FEAT_ATTR(name, FEAT_INCOMPAT, BTRFS_FEATURE_INCOMPAT, feature)
61
62/* convert from attribute */
David Sterba093adbc2015-02-24 19:40:41 +010063static inline struct btrfs_feature_attr *
64to_btrfs_feature_attr(struct kobj_attribute *a)
65{
66 return container_of(a, struct btrfs_feature_attr, kobj_attr);
67}
68
69static inline struct kobj_attribute *attr_to_btrfs_attr(struct attribute *attr)
70{
71 return container_of(attr, struct kobj_attribute, attr);
72}
73
74static inline struct btrfs_feature_attr *
75attr_to_btrfs_feature_attr(struct attribute *attr)
76{
77 return to_btrfs_feature_attr(attr_to_btrfs_attr(attr));
78}
79
Jeff Mahoney3b02a682013-11-01 13:07:02 -040080char *btrfs_printable_features(enum btrfs_feature_set set, u64 flags);
David Sterbaf10152b2019-08-01 19:07:55 +020081const char * const btrfs_feature_set_name(enum btrfs_feature_set set);
Anand Jaine3bd6972015-08-14 18:32:48 +080082int btrfs_sysfs_add_device_link(struct btrfs_fs_devices *fs_devices,
Anand Jain0d393762014-06-03 11:36:01 +080083 struct btrfs_device *one_device);
Anand Jain32576042015-08-14 18:32:49 +080084int btrfs_sysfs_rm_device_link(struct btrfs_fs_devices *fs_devices,
Anand Jain99994cd2014-06-03 11:36:00 +080085 struct btrfs_device *one_device);
Anand Jain0c10e2d2015-03-10 06:38:35 +080086int btrfs_sysfs_add_fsid(struct btrfs_fs_devices *fs_devs,
87 struct kobject *parent);
Anand Jainef1a0da2015-03-10 06:38:36 +080088int btrfs_sysfs_add_device(struct btrfs_fs_devices *fs_devs);
Anand Jain1d1c1be2015-03-10 06:38:37 +080089void btrfs_sysfs_remove_fsid(struct btrfs_fs_devices *fs_devs);
David Sterba444e7512016-01-21 18:50:40 +010090void btrfs_sysfs_feature_update(struct btrfs_fs_info *fs_info,
91 u64 bit, enum btrfs_feature_set set);
David Sterba5b286922019-08-01 18:50:16 +020092void btrfs_kobject_uevent(struct block_device *bdev, enum kobject_action action);
David Sterba444e7512016-01-21 18:50:40 +010093
David Sterba89439102019-08-01 17:34:41 +020094int __init btrfs_init_sysfs(void);
95void __cold btrfs_exit_sysfs(void);
96int btrfs_sysfs_add_mounted(struct btrfs_fs_info *fs_info);
97void btrfs_sysfs_remove_mounted(struct btrfs_fs_info *fs_info);
David Sterba32a99912019-08-01 17:49:55 +020098void btrfs_sysfs_add_block_group_type(struct btrfs_block_group_cache *cache);
David Sterbab8823272019-08-01 18:50:16 +020099int btrfs_sysfs_add_space_info_type(struct btrfs_fs_info *fs_info,
100 struct btrfs_space_info *space_info);
David Sterbab5865ba2019-08-01 18:50:16 +0200101void btrfs_sysfs_remove_space_info(struct btrfs_space_info *space_info);
David Sterba89439102019-08-01 17:34:41 +0200102
David Sterba9888c342018-04-03 19:16:55 +0200103#endif