[Ocfs2-tools-devel] [PATCH 02/13] libocfs2: Add an incompat feature flag OCFS2_FEATURE_INCOMPAT_CLUSTERINFO
Sunil Mushran
sunil.mushran at oracle.com
Mon Dec 20 12:02:50 PST 2010
OCFS2_FEATURE_INCOMPAT_CLUSTERINFO allows us to use sb->s_cluster_info for
both userspace and o2cb cluster stacks. It also allows us to extend cluster
info to include stack flags.
This incompat flag can be set/cleared using tunefs.ocfs2 --fs-features.
Signed-off-by: Sunil Mushran <sunil.mushran at oracle.com>
---
debugfs.ocfs2/dump.c | 2 +-
include/ocfs2-kernel/ocfs2_fs.h | 18 +++++++++++++-----
include/ocfs2/ocfs2.h | 25 ++++++++++++++++++++++++-
libocfs2/checkhb.c | 2 +-
libocfs2/dlm.c | 2 +-
libocfs2/feature_string.c | 9 +++++++++
mkfs.ocfs2/check.c | 2 +-
7 files changed, 50 insertions(+), 10 deletions(-)
diff --git a/debugfs.ocfs2/dump.c b/debugfs.ocfs2/dump.c
index 482b56f..32bcb6e 100644
--- a/debugfs.ocfs2/dump.c
+++ b/debugfs.ocfs2/dump.c
@@ -93,7 +93,7 @@ void dump_super_block(FILE *out, struct ocfs2_super_block *sb)
for (i = 0; i < 3; i++)
fprintf(out, "\tDX Seed[%d]: 0x%08x\n", i, sb->s_dx_seed[i]);
- if (ocfs2_userspace_stack(sb))
+ if (ocfs2_clusterinfo_valid(sb))
fprintf(out,
"\tCluster stack: %s\n"
"\tCluster name: %s\n",
diff --git a/include/ocfs2-kernel/ocfs2_fs.h b/include/ocfs2-kernel/ocfs2_fs.h
index ffda634..5d335ad 100644
--- a/include/ocfs2-kernel/ocfs2_fs.h
+++ b/include/ocfs2-kernel/ocfs2_fs.h
@@ -101,7 +101,8 @@
| OCFS2_FEATURE_INCOMPAT_XATTR \
| OCFS2_FEATURE_INCOMPAT_REFCOUNT_TREE \
| OCFS2_FEATURE_INCOMPAT_INDEXED_DIRS \
- | OCFS2_FEATURE_INCOMPAT_DISCONTIG_BG)
+ | OCFS2_FEATURE_INCOMPAT_DISCONTIG_BG \
+ | OCFS2_FEATURE_INCOMPAT_CLUSTERINFO)
#define OCFS2_FEATURE_RO_COMPAT_SUPP (OCFS2_FEATURE_RO_COMPAT_UNWRITTEN \
| OCFS2_FEATURE_RO_COMPAT_USRQUOTA \
| OCFS2_FEATURE_RO_COMPAT_GRPQUOTA)
@@ -170,6 +171,13 @@
#define OCFS2_FEATURE_INCOMPAT_DISCONTIG_BG 0x2000
/*
+ * Incompat bit to indicate useable clusterinfo with stackflags for all
+ * cluster stacks (userspace adnd o2cb). If this bit is set,
+ * INCOMPAT_USERSPACE_STACK becomes superfluous and thus should not be set.
+ */
+#define OCFS2_FEATURE_INCOMPAT_CLUSTERINFO 0x4000
+
+/*
* backup superblock flag is used to indicate that this volume
* has backup superblocks.
*/
@@ -282,7 +290,7 @@
#define OCFS2_VOL_UUID_LEN 16
#define OCFS2_MAX_VOL_LABEL_LEN 64
-/* The alternate, userspace stack fields */
+/* The cluster stack fields */
#define OCFS2_STACK_LABEL_LEN 4
#define OCFS2_CLUSTER_NAME_LEN 16
@@ -602,9 +610,9 @@ struct ocfs2_super_block {
* group header */
/*50*/ __u8 s_label[OCFS2_MAX_VOL_LABEL_LEN]; /* Label for mounting, etc. */
/*90*/ __u8 s_uuid[OCFS2_VOL_UUID_LEN]; /* 128-bit uuid */
-/*A0*/ struct ocfs2_cluster_info s_cluster_info; /* Selected userspace
- stack. Only valid
- with INCOMPAT flag. */
+/*A0*/ struct ocfs2_cluster_info s_cluster_info; /* Only valid if either
+ userspace or clusterinfo
+ INCOMPAT flag set. */
/*B8*/ __le16 s_xattr_inline_size; /* extended attribute inline size
for this fs*/
__le16 s_reserved0;
diff --git a/include/ocfs2/ocfs2.h b/include/ocfs2/ocfs2.h
index 0df8c96..04d4b21 100644
--- a/include/ocfs2/ocfs2.h
+++ b/include/ocfs2/ocfs2.h
@@ -136,6 +136,9 @@
#define OCFS2_QF_INFO_DIRTY 1
#define OCFS2_QF_INFO_LOADED 2
+/* Classic (historically speaking) cluster stack */
+#define OCFS2_CLASSIC_CLUSTER_STACK "o2cb"
+
typedef void (*ocfs2_chb_notify)(int state, char *progress, void *data);
typedef struct _ocfs2_filesys ocfs2_filesys;
@@ -1237,9 +1240,29 @@ static inline int ocfs2_sparse_alloc(struct ocfs2_super_block *osb)
return 0;
}
+static inline int ocfs2_clusterinfo_valid(struct ocfs2_super_block *osb)
+{
+ if (osb->s_feature_incompat &
+ (OCFS2_FEATURE_INCOMPAT_USERSPACE_STACK |
+ OCFS2_FEATURE_INCOMPAT_CLUSTERINFO))
+ return 1;
+ return 0;
+}
+
static inline int ocfs2_userspace_stack(struct ocfs2_super_block *osb)
{
- if (osb->s_feature_incompat & OCFS2_FEATURE_INCOMPAT_USERSPACE_STACK)
+ if (ocfs2_clusterinfo_valid(osb) &&
+ memcmp(osb->s_cluster_info.ci_stack, OCFS2_CLASSIC_CLUSTER_STACK,
+ OCFS2_STACK_LABEL_LEN))
+ return 1;
+ return 0;
+}
+
+static inline int ocfs2_o2cb_stack(struct ocfs2_super_block *osb)
+{
+ if (ocfs2_clusterinfo_valid(osb) &&
+ !memcmp(osb->s_cluster_info.ci_stack, OCFS2_CLASSIC_CLUSTER_STACK,
+ OCFS2_STACK_LABEL_LEN))
return 1;
return 0;
}
diff --git a/libocfs2/checkhb.c b/libocfs2/checkhb.c
index 0c28f80..9b57697 100644
--- a/libocfs2/checkhb.c
+++ b/libocfs2/checkhb.c
@@ -99,7 +99,7 @@ errcode_t ocfs2_check_heartbeats(struct list_head *dev_list, int ignore_local)
if (OCFS2_HAS_INCOMPAT_FEATURE(OCFS2_RAW_SB(fs->fs_super),
OCFS2_FEATURE_INCOMPAT_LOCAL_MOUNT))
snprintf(dev->stack, sizeof(dev->stack), "%s", "local");
- else if (ocfs2_userspace_stack(OCFS2_RAW_SB(fs->fs_super)))
+ else if (ocfs2_clusterinfo_valid(OCFS2_RAW_SB(fs->fs_super)))
snprintf(dev->stack, sizeof(dev->stack), "%.*s",
OCFS2_STACK_LABEL_LEN,
OCFS2_RAW_SB(fs->fs_super)->s_cluster_info.ci_stack);
diff --git a/libocfs2/dlm.c b/libocfs2/dlm.c
index 4c8cda8..8751c07 100644
--- a/libocfs2/dlm.c
+++ b/libocfs2/dlm.c
@@ -107,7 +107,7 @@ errcode_t ocfs2_fill_cluster_desc(ocfs2_filesys *fs,
errcode_t ret = 0;
struct ocfs2_super_block *sb = OCFS2_RAW_SB(fs->fs_super);
- if (!ocfs2_userspace_stack(sb)) {
+ if (!ocfs2_clusterinfo_valid(sb)) {
desc->c_stack = NULL;
desc->c_cluster = NULL;
return 0;
diff --git a/libocfs2/feature_string.c b/libocfs2/feature_string.c
index 0f3dcf8..2a052e9 100644
--- a/libocfs2/feature_string.c
+++ b/libocfs2/feature_string.c
@@ -181,6 +181,11 @@ static struct fs_feature_flags ocfs2_supported_features[] = {
{0, OCFS2_FEATURE_INCOMPAT_DISCONTIG_BG, 0},
},
{
+ "clusterinfo",
+ {0, OCFS2_FEATURE_INCOMPAT_CLUSTERINFO, 0},
+ {0, OCFS2_FEATURE_INCOMPAT_CLUSTERINFO, 0},
+ },
+ {
NULL,
{0, 0, 0},
{0, 0, 0}
@@ -268,6 +273,10 @@ static struct feature_name ocfs2_feature_names[] = {
.fn_flag = {0, OCFS2_FEATURE_INCOMPAT_DISCONTIG_BG, 0},
},
{
+ .fn_name = "clusterinfo",
+ .fn_flag = {0, OCFS2_FEATURE_INCOMPAT_CLUSTERINFO, 0},
+ },
+ {
.fn_name = NULL,
},
};
diff --git a/mkfs.ocfs2/check.c b/mkfs.ocfs2/check.c
index e48707e..597b87b 100644
--- a/mkfs.ocfs2/check.c
+++ b/mkfs.ocfs2/check.c
@@ -64,7 +64,7 @@ static void disk_fill(const char *device, char **stack_name,
if (err)
return;
- if (!ocfs2_userspace_stack(OCFS2_RAW_SB(fs->fs_super))) {
+ if (!ocfs2_clusterinfo_valid(OCFS2_RAW_SB(fs->fs_super))) {
*stack_name = strdup("o2cb");
goto close;
}
--
1.7.1
More information about the Ocfs2-tools-devel
mailing list