2013-11-02 01:06:57 +08:00
|
|
|
#ifndef _BTRFS_SYSFS_H_
|
|
|
|
#define _BTRFS_SYSFS_H_
|
|
|
|
|
2014-02-05 22:36:18 +08:00
|
|
|
/*
|
|
|
|
* Data exported through sysfs
|
|
|
|
*/
|
|
|
|
extern u64 btrfs_debugfs_test;
|
|
|
|
|
2013-11-02 01:06:57 +08:00
|
|
|
enum btrfs_feature_set {
|
|
|
|
FEAT_COMPAT,
|
|
|
|
FEAT_COMPAT_RO,
|
|
|
|
FEAT_INCOMPAT,
|
|
|
|
FEAT_MAX
|
|
|
|
};
|
|
|
|
|
|
|
|
#define __INIT_KOBJ_ATTR(_name, _mode, _show, _store) \
|
|
|
|
{ \
|
|
|
|
.attr = { .name = __stringify(_name), .mode = _mode }, \
|
|
|
|
.show = _show, \
|
|
|
|
.store = _store, \
|
|
|
|
}
|
|
|
|
|
2014-07-30 20:04:09 +08:00
|
|
|
#define BTRFS_ATTR_RW(_name, _show, _store) \
|
2014-07-30 20:04:08 +08:00
|
|
|
static struct kobj_attribute btrfs_attr_##_name = \
|
2014-07-30 20:04:09 +08:00
|
|
|
__INIT_KOBJ_ATTR(_name, 0644, _show, _store)
|
2014-07-30 20:04:08 +08:00
|
|
|
|
|
|
|
#define BTRFS_ATTR(_name, _show) \
|
2014-07-30 20:04:09 +08:00
|
|
|
static struct kobj_attribute btrfs_attr_##_name = \
|
|
|
|
__INIT_KOBJ_ATTR(_name, 0444, _show, NULL)
|
2014-07-30 20:04:08 +08:00
|
|
|
|
2013-11-02 01:06:58 +08:00
|
|
|
#define BTRFS_ATTR_PTR(_name) (&btrfs_attr_##_name.attr)
|
|
|
|
|
2013-11-02 01:07:04 +08:00
|
|
|
#define BTRFS_RAID_ATTR(_name, _show) \
|
2014-07-30 20:04:08 +08:00
|
|
|
static struct kobj_attribute btrfs_raid_attr_##_name = \
|
2013-11-02 01:07:04 +08:00
|
|
|
__INIT_KOBJ_ATTR(_name, 0444, _show, NULL)
|
2014-07-30 20:04:08 +08:00
|
|
|
|
2013-11-02 01:07:04 +08:00
|
|
|
#define BTRFS_RAID_ATTR_PTR(_name) (&btrfs_raid_attr_##_name.attr)
|
|
|
|
|
|
|
|
|
2013-11-02 01:06:57 +08:00
|
|
|
struct btrfs_feature_attr {
|
|
|
|
struct kobj_attribute kobj_attr;
|
|
|
|
enum btrfs_feature_set feature_set;
|
|
|
|
u64 feature_bit;
|
|
|
|
};
|
|
|
|
|
|
|
|
#define BTRFS_FEAT_ATTR(_name, _feature_set, _prefix, _feature_bit) \
|
|
|
|
static struct btrfs_feature_attr btrfs_attr_##_name = { \
|
|
|
|
.kobj_attr = __INIT_KOBJ_ATTR(_name, S_IRUGO, \
|
2013-11-02 01:07:01 +08:00
|
|
|
btrfs_feature_attr_show, \
|
|
|
|
btrfs_feature_attr_store), \
|
2013-11-02 01:06:57 +08:00
|
|
|
.feature_set = _feature_set, \
|
|
|
|
.feature_bit = _prefix ##_## _feature_bit, \
|
|
|
|
}
|
|
|
|
#define BTRFS_FEAT_ATTR_PTR(_name) (&btrfs_attr_##_name.kobj_attr.attr)
|
|
|
|
|
|
|
|
#define BTRFS_FEAT_ATTR_COMPAT(name, feature) \
|
|
|
|
BTRFS_FEAT_ATTR(name, FEAT_COMPAT, BTRFS_FEATURE_COMPAT, feature)
|
|
|
|
#define BTRFS_FEAT_ATTR_COMPAT_RO(name, feature) \
|
|
|
|
BTRFS_FEAT_ATTR(name, FEAT_COMPAT_RO, BTRFS_FEATURE_COMPAT, feature)
|
|
|
|
#define BTRFS_FEAT_ATTR_INCOMPAT(name, feature) \
|
|
|
|
BTRFS_FEAT_ATTR(name, FEAT_INCOMPAT, BTRFS_FEATURE_INCOMPAT, feature)
|
|
|
|
|
|
|
|
/* convert from attribute */
|
2015-02-25 02:40:41 +08:00
|
|
|
static inline struct btrfs_feature_attr *
|
|
|
|
to_btrfs_feature_attr(struct kobj_attribute *a)
|
|
|
|
{
|
|
|
|
return container_of(a, struct btrfs_feature_attr, kobj_attr);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline struct kobj_attribute *attr_to_btrfs_attr(struct attribute *attr)
|
|
|
|
{
|
|
|
|
return container_of(attr, struct kobj_attribute, attr);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline struct btrfs_feature_attr *
|
|
|
|
attr_to_btrfs_feature_attr(struct attribute *attr)
|
|
|
|
{
|
|
|
|
return to_btrfs_feature_attr(attr_to_btrfs_attr(attr));
|
|
|
|
}
|
|
|
|
|
2013-11-02 01:07:02 +08:00
|
|
|
char *btrfs_printable_features(enum btrfs_feature_set set, u64 flags);
|
|
|
|
extern const char * const btrfs_feature_set_names[3];
|
2013-11-02 01:07:04 +08:00
|
|
|
extern struct kobj_type space_info_ktype;
|
|
|
|
extern struct kobj_type btrfs_raid_ktype;
|
2014-06-03 11:36:01 +08:00
|
|
|
int btrfs_kobj_add_device(struct btrfs_fs_info *fs_info,
|
|
|
|
struct btrfs_device *one_device);
|
2014-06-03 11:36:00 +08:00
|
|
|
int btrfs_kobj_rm_device(struct btrfs_fs_info *fs_info,
|
|
|
|
struct btrfs_device *one_device);
|
2013-11-02 01:06:57 +08:00
|
|
|
#endif /* _BTRFS_SYSFS_H_ */
|