forked from pool/bcache-tools
Jan Engelhardt
3dff4d17f4
- Remove dependence of smartcols bcache-tools.spec, bcache-tools code doesn't need it now. (jsc#SLE-9807) - Remove 1001-udev-do-not-rely-on-DRIVER-variable.patch because we have 0013-bcache-tools-Export-CACHED_UUID-and-CACHED_LABEL.patch to provide static UUIDs. (jsc#SLE-9807) - bcache-tools: add man page bcache-status.8 (jsc#SLE-9807) 0017-bcache-tools-add-man-page-bcache-status.8.patch - bcache-tools: add bcache-status (jsc#SLE-9807) 0016-bcache-tools-add-bcache-status.patch - bcache-tools: make: permit only one cache device to be specified (jsc#SLE-9807) 0015-bcache-tools-make-permit-only-one-cache-device-to-be.patch - bcache-tools: Remove the dependency on libsmartcols (jsc#SLE-9807) 0014-bcache-tools-Remove-the-dependency-on-libsmartcols.patch - bcache-tools: Export CACHED_UUID and CACHED_LABEL (jsc#SLE-9807) 0013-bcache-tools-Export-CACHED_UUID-and-CACHED_LABEL.patch - bcache-tools: Fix potential coredump issues (jsc#SLE-9807) 0012-bcache-tools-Fix-potential-coredump-issues.patch - bcache-tools: add print_cache_set_supported_feature_sets() in lib.c (jsc#SLE-9807) 0011-bcache-tools-add-print_cache_set_supported_feature_s.patch - bcache-tools: add large_bucket incompat feature (jsc#SLE-9807) 0010-bcache-tools-add-large_bucket-incompat-feature.patch - bcache-tools: upgrade super block versions for feature sets (jsc#SLE-9807) 0009-bcache-tools-upgrade-super-block-versions-for-featur.patch - bcache-tools: define separated super block for in-memory and on-disk format (jsc#SLE-9807) OBS-URL: https://build.opensuse.org/request/show/841483 OBS-URL: https://build.opensuse.org/package/show/filesystems/bcache-tools?expand=0&rev=27
229 lines
6.6 KiB
Diff
229 lines
6.6 KiB
Diff
From 5e7bd462ee91793708d6f0c34c46fb904bee7efb Mon Sep 17 00:00:00 2001
|
|
From: Coly Li <colyli@suse.de>
|
|
Date: Mon, 17 Aug 2020 00:40:17 +0800
|
|
Subject: [PATCH 09/17] bcache-tools: upgrade super block versions for feature
|
|
sets
|
|
Git-commit: 5e7bd462ee91793708d6f0c34c46fb904bee7efb
|
|
Patch-mainline: bcache-tools-1.1
|
|
References: jsc#SLE-9807
|
|
|
|
This patch upgrades super block versions for adding feature sets into
|
|
struct cache_sb_disk,
|
|
128 __u64 feature_compat;
|
|
129 __u64 feature_incompat;
|
|
130 __u64 feature_ro_compat;
|
|
|
|
With the feature set flags, it will be convenient to add new features
|
|
without upgrade super block version again (at least for a long time).
|
|
|
|
The new added versions are,
|
|
- BCACHE_SB_VERSION_CDEV_WITH_FEATURES for cache device super block
|
|
- BCACHE_SB_VERSION_BDEV_WITH_FEATURES for backing device super block
|
|
|
|
The feature set flags are also added into the in-memory super block
|
|
struct cache_sb. The feature sets conversion between cache_sb_disk and
|
|
cache_sb also added into to_cache_sb() and to_cache_sb_disk().
|
|
|
|
Some feature sets related macros are also added into bcache.h, and a new
|
|
file feature.c is added for future new features record and display.
|
|
|
|
Signed-off-by: Coly Li <colyli@suse.de>
|
|
---
|
|
Makefile | 2 +-
|
|
bcache.h | 85 ++++++++++++++++++++++++++++++++++++++++++++++++++++--
|
|
features.c | 22 ++++++++++++++
|
|
lib.c | 12 ++++++++
|
|
4 files changed, 118 insertions(+), 3 deletions(-)
|
|
create mode 100644 features.c
|
|
|
|
diff --git a/Makefile b/Makefile
|
|
index b4546a1..8b87a67 100644
|
|
--- a/Makefile
|
|
+++ b/Makefile
|
|
@@ -38,4 +38,4 @@ bcache-register: bcache-register.o
|
|
bcache: CFLAGS += `pkg-config --cflags blkid uuid smartcols`
|
|
bcache: LDLIBS += `pkg-config --libs blkid uuid smartcols`
|
|
bcache: CFLAGS += -std=gnu99
|
|
-bcache: crc64.o lib.o make.o zoned.o
|
|
+bcache: crc64.o lib.o make.o zoned.o features.o
|
|
diff --git a/bcache.h b/bcache.h
|
|
index 250da9d..9d969e1 100644
|
|
--- a/bcache.h
|
|
+++ b/bcache.h
|
|
@@ -29,12 +29,16 @@ static const char bcache_magic[] = {
|
|
* Version 2: Seed pointer into btree node checksum
|
|
* Version 3: Cache device with new UUID format
|
|
* Version 4: Backing device with data offset
|
|
+ * Version 5: Cache adn backing devices with compat/incompat/ro_compat
|
|
+ * feature sets
|
|
*/
|
|
#define BCACHE_SB_VERSION_CDEV 0
|
|
#define BCACHE_SB_VERSION_BDEV 1
|
|
#define BCACHE_SB_VERSION_CDEV_WITH_UUID 3
|
|
#define BCACHE_SB_VERSION_BDEV_WITH_OFFSET 4
|
|
-#define BCACHE_SB_MAX_VERSION 4
|
|
+#define BCACHE_SB_VERSION_CDEV_WITH_FEATURES 5
|
|
+#define BCACHE_SB_VERSION_BDEV_WITH_FEATURES 6
|
|
+#define BCACHE_SB_MAX_VERSION 6
|
|
|
|
#define SB_SECTOR 8
|
|
#define SB_LABEL_SIZE 32
|
|
@@ -59,7 +63,11 @@ struct cache_sb_disk {
|
|
__le64 flags;
|
|
__le64 seq;
|
|
|
|
- __le64 pad[8];
|
|
+ __le64 feature_compat;
|
|
+ __le64 feature_incompat;
|
|
+ __le64 feature_ro_compat;
|
|
+
|
|
+ __le64 pad[5];
|
|
|
|
union {
|
|
struct {
|
|
@@ -116,6 +124,10 @@ struct cache_sb {
|
|
__u64 flags;
|
|
__u64 seq;
|
|
|
|
+ __u64 feature_compat;
|
|
+ __u64 feature_incompat;
|
|
+ __u64 feature_ro_compat;
|
|
+
|
|
union {
|
|
struct {
|
|
/* Cache devices */
|
|
@@ -180,4 +192,73 @@ uint64_t crc64(const void *data, size_t len);
|
|
#define csum_set(i) \
|
|
crc64(((void *) (i)) + 8, ((void *) end(i)) - (((void *) (i)) + 8))
|
|
|
|
+/* Feature set definition */
|
|
+
|
|
+#define BCH_FEATURE_COMPAT 0
|
|
+#define BCH_FEATURE_RO_COMPAT 1
|
|
+#define BCH_FEATURE_INCOMPAT 2
|
|
+#define BCH_FEATURE_TYPE_MASK 0x03
|
|
+
|
|
+#define BCH_FEATURE_COMPAT_SUUP 0
|
|
+#define BCH_FEATURE_INCOMPAT_SUUP 0
|
|
+#define BCH_FEATURE_RO_COMPAT_SUUP 0
|
|
+
|
|
+#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; \
|
|
+}
|
|
+
|
|
#endif
|
|
diff --git a/features.c b/features.c
|
|
new file mode 100644
|
|
index 0000000..a1c9884
|
|
--- /dev/null
|
|
+++ b/features.c
|
|
@@ -0,0 +1,22 @@
|
|
+// SPDX-License-Identifier: GPL-2.0
|
|
+/*
|
|
+ * Author: Coly Li <colyli@suse.de>
|
|
+ *
|
|
+ * Inspired by e2fsprogs features compat/incompat/ro_compat
|
|
+ * related code.
|
|
+ */
|
|
+#include <stdbool.h>
|
|
+#include <stdint.h>
|
|
+#include <sys/types.h>
|
|
+
|
|
+#include "bcache.h"
|
|
+
|
|
+struct feature {
|
|
+ int compat;
|
|
+ unsigned int mask;
|
|
+ const char *string;
|
|
+};
|
|
+
|
|
+static struct feature feature_list[] = {
|
|
+ {0, 0, 0 },
|
|
+};
|
|
diff --git a/lib.c b/lib.c
|
|
index 9a2fa26..dcf752c 100644
|
|
--- a/lib.c
|
|
+++ b/lib.c
|
|
@@ -730,6 +730,12 @@ struct cache_sb *to_cache_sb(struct cache_sb *sb,
|
|
sb->d[i]= le64_to_cpu(sb_disk->d[i]);
|
|
}
|
|
|
|
+ if (sb->version >= BCACHE_SB_VERSION_CDEV_WITH_FEATURES) {
|
|
+ sb->feature_compat = le64_to_cpu(sb_disk->feature_compat);
|
|
+ sb->feature_incompat = le64_to_cpu(sb_disk->feature_incompat);
|
|
+ sb->feature_ro_compat = le64_to_cpu(sb_disk->feature_ro_compat);
|
|
+ }
|
|
+
|
|
return sb;
|
|
}
|
|
|
|
@@ -772,5 +778,11 @@ struct cache_sb_disk *to_cache_sb_disk(struct cache_sb_disk *sb_disk,
|
|
sb_disk->d[i] = cpu_to_le64(sb->d[i]);
|
|
}
|
|
|
|
+ if (sb->version >= BCACHE_SB_VERSION_CDEV_WITH_FEATURES) {
|
|
+ sb_disk->feature_compat = cpu_to_le64(sb->feature_compat);
|
|
+ sb_disk->feature_incompat = cpu_to_le64(sb->feature_incompat);
|
|
+ sb_disk->feature_ro_compat = cpu_to_le64(sb->feature_ro_compat);
|
|
+ }
|
|
+
|
|
return sb_disk;
|
|
}
|
|
--
|
|
2.26.2
|
|
|