092bd54d69
The following three sysfs files are created to display according feature set information of bcache: /sys/fs/bcache/<cache set UUID>/internal/feature_compat /sys/fs/bcache/<cache set UUID>/internal/feature_ro_compat /sys/fs/bcache/<cache set UUID>/internal/feature_incompat is added by this patch, to display feature sets information of the cache set. Now only an incompat feature 'large_bucket' added in bcache, the sysfs file content is: [large_bucket] string large_bucket means the running bcache drive supports incompat feature 'large_bucket', the wrapping [] means the 'large_bucket' feature is currently enabled on this cache set. This patch is ready to display compat and ro_compat features, in future once bcache code implements such feature sets, the according feature strings will be displayed in their sysfs files too. Signed-off-by: Coly Li <colyli@suse.de> Signed-off-by: Jens Axboe <axboe@kernel.dk>
87 lines
2.6 KiB
C
87 lines
2.6 KiB
C
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
|
|
#ifndef _BCACHE_FEATURES_H
|
|
#define _BCACHE_FEATURES_H
|
|
|
|
#include <linux/bcache.h>
|
|
#include <linux/kernel.h>
|
|
#include <linux/types.h>
|
|
|
|
#define BCH_FEATURE_COMPAT 0
|
|
#define BCH_FEATURE_RO_COMPAT 1
|
|
#define BCH_FEATURE_INCOMPAT 2
|
|
#define BCH_FEATURE_TYPE_MASK 0x03
|
|
|
|
/* Feature set definition */
|
|
/* Incompat feature set */
|
|
#define BCH_FEATURE_INCOMPAT_LARGE_BUCKET 0x0001 /* 32bit bucket size */
|
|
|
|
#define BCH_FEATURE_COMPAT_SUUP 0
|
|
#define BCH_FEATURE_RO_COMPAT_SUUP 0
|
|
#define BCH_FEATURE_INCOMPAT_SUUP BCH_FEATURE_INCOMPAT_LARGE_BUCKET
|
|
|
|
#define BCH_HAS_COMPAT_FEATURE(sb, mask) \
|
|
((sb)->feature_compat & (mask))
|
|
#define BCH_HAS_RO_COMPAT_FEATURE(sb, mask) \
|
|
((sb)->feature_ro_compat & (mask))
|
|
#define BCH_HAS_INCOMPAT_FEATURE(sb, mask) \
|
|
((sb)->feature_incompat & (mask))
|
|
|
|
#define BCH_FEATURE_COMPAT_FUNCS(name, flagname) \
|
|
static inline int bch_has_feature_##name(struct cache_sb *sb) \
|
|
{ \
|
|
return (((sb)->feature_compat & \
|
|
BCH##_FEATURE_COMPAT_##flagname) != 0); \
|
|
} \
|
|
static inline void bch_set_feature_##name(struct cache_sb *sb) \
|
|
{ \
|
|
(sb)->feature_compat |= \
|
|
BCH##_FEATURE_COMPAT_##flagname; \
|
|
} \
|
|
static inline void bch_clear_feature_##name(struct cache_sb *sb) \
|
|
{ \
|
|
(sb)->feature_compat &= \
|
|
~BCH##_FEATURE_COMPAT_##flagname; \
|
|
}
|
|
|
|
#define BCH_FEATURE_RO_COMPAT_FUNCS(name, flagname) \
|
|
static inline int bch_has_feature_##name(struct cache_sb *sb) \
|
|
{ \
|
|
return (((sb)->feature_ro_compat & \
|
|
BCH##_FEATURE_RO_COMPAT_##flagname) != 0); \
|
|
} \
|
|
static inline void bch_set_feature_##name(struct cache_sb *sb) \
|
|
{ \
|
|
(sb)->feature_ro_compat |= \
|
|
BCH##_FEATURE_RO_COMPAT_##flagname; \
|
|
} \
|
|
static inline void bch_clear_feature_##name(struct cache_sb *sb) \
|
|
{ \
|
|
(sb)->feature_ro_compat &= \
|
|
~BCH##_FEATURE_RO_COMPAT_##flagname; \
|
|
}
|
|
|
|
#define BCH_FEATURE_INCOMPAT_FUNCS(name, flagname) \
|
|
static inline int bch_has_feature_##name(struct cache_sb *sb) \
|
|
{ \
|
|
return (((sb)->feature_incompat & \
|
|
BCH##_FEATURE_INCOMPAT_##flagname) != 0); \
|
|
} \
|
|
static inline void bch_set_feature_##name(struct cache_sb *sb) \
|
|
{ \
|
|
(sb)->feature_incompat |= \
|
|
BCH##_FEATURE_INCOMPAT_##flagname; \
|
|
} \
|
|
static inline void bch_clear_feature_##name(struct cache_sb *sb) \
|
|
{ \
|
|
(sb)->feature_incompat &= \
|
|
~BCH##_FEATURE_INCOMPAT_##flagname; \
|
|
}
|
|
|
|
BCH_FEATURE_INCOMPAT_FUNCS(large_bucket, LARGE_BUCKET);
|
|
|
|
int bch_print_cache_set_feature_compat(struct cache_set *c, char *buf, int size);
|
|
int bch_print_cache_set_feature_ro_compat(struct cache_set *c, char *buf, int size);
|
|
int bch_print_cache_set_feature_incompat(struct cache_set *c, char *buf, int size);
|
|
|
|
#endif
|