[Ocfs2-tools-devel] [PATCH 05/13] libocfs2: Add c_flags to struct o2cb_cluster_desc
Sunil Mushran
sunil.mushran at oracle.com
Mon Dec 20 12:02:53 PST 2010
ocfs2_fill_cluster_desc() and ocfs2_set_cluster_desc() are now aware of
cluster flags.
Signed-off-by: Sunil Mushran <sunil.mushran at oracle.com>
---
include/o2cb/o2cb.h | 1 +
include/ocfs2/ocfs2.h | 2 +
libo2cb/o2cb_abi.c | 53 ++++++++++++++++++++++++++++++++----------------
libo2cb/o2cb_abi.h | 5 ++++
libocfs2/dlm.c | 51 +++++++++++++++++++++++++++++++++++++++++++++++
5 files changed, 94 insertions(+), 18 deletions(-)
diff --git a/include/o2cb/o2cb.h b/include/o2cb/o2cb.h
index 8526ad7..e1c0d43 100644
--- a/include/o2cb/o2cb.h
+++ b/include/o2cb/o2cb.h
@@ -84,6 +84,7 @@ struct o2cb_cluster_desc {
char *c_cluster; /* The name of the cluster, NULL for the
default cluster, which is only valid in
the classic stack. */
+ uint8_t c_flags;
};
struct o2cb_region_desc {
diff --git a/include/ocfs2/ocfs2.h b/include/ocfs2/ocfs2.h
index e820c78..91d160e 100644
--- a/include/ocfs2/ocfs2.h
+++ b/include/ocfs2/ocfs2.h
@@ -788,6 +788,8 @@ errcode_t ocfs2_file_write(ocfs2_cached_inode *ci, void *buf, uint32_t count,
errcode_t ocfs2_fill_cluster_desc(ocfs2_filesys *fs,
struct o2cb_cluster_desc *desc);
+errcode_t ocfs2_set_cluster_flags(ocfs2_filesys *fs,
+ struct o2cb_cluster_desc *desc);
errcode_t ocfs2_set_cluster_desc(ocfs2_filesys *fs,
struct o2cb_cluster_desc *desc);
errcode_t ocfs2_fill_heartbeat_desc(ocfs2_filesys *fs,
diff --git a/libo2cb/o2cb_abi.c b/libo2cb/o2cb_abi.c
index 2ce1a40..b0d881f 100644
--- a/libo2cb/o2cb_abi.c
+++ b/libo2cb/o2cb_abi.c
@@ -1719,38 +1719,55 @@ errcode_t o2cb_running_cluster_desc(struct o2cb_cluster_desc *cluster)
errcode_t err;
const char *stack;
char **clusters = NULL;
+ int globalhb;
+ cluster->c_stack = NULL;
+ cluster->c_cluster = NULL;
+ cluster->c_flags = 0;
+
+ /* c_stack */
err = o2cb_get_stack_name(&stack);
if (err)
- return err;
-
- if (!strcmp(stack, classic_stack.s_name)) {
- cluster->c_stack = NULL;
- cluster->c_cluster = NULL;
- return 0;
- }
+ goto out;
+ err = O2CB_ET_NO_MEMORY;
cluster->c_stack = strdup(stack);
if (!cluster->c_stack)
- return O2CB_ET_NO_MEMORY;
+ goto out;
+ /* c_cluster */
err = o2cb_list_clusters(&clusters);
- if (err) {
- free(cluster->c_stack);
- return err;
- }
+ if (err)
+ goto out;
/* The first cluster is the default cluster */
- if (clusters[0]) {
+ if (!clusters[0])
+ err = O2CB_ET_SERVICE_UNAVAILABLE;
+ else {
cluster->c_cluster = strdup(clusters[0]);
- if (!cluster->c_cluster) {
- free(cluster->c_stack);
+ if (!cluster->c_cluster)
err = O2CB_ET_NO_MEMORY;
- }
}
- o2cb_free_cluster_list(clusters);
+ if (err)
+ goto out;
- return 0;
+ /* c_flags */
+ err = o2cb_global_heartbeat_mode(cluster->c_cluster, &globalhb);
+ if (err)
+ goto out;
+
+ if (globalhb)
+ cluster->c_flags |= OCFS2_CLUSTER_O2CB_GLOBAL_HEARTBEAT;
+
+out:
+ if (clusters)
+ o2cb_free_cluster_list(clusters);
+ if (err) {
+ free(cluster->c_stack);
+ free(cluster->c_cluster);
+ }
+
+ return err;
}
static inline int is_dots(const char *name)
diff --git a/libo2cb/o2cb_abi.h b/libo2cb/o2cb_abi.h
index 0b387be..677944f 100644
--- a/libo2cb/o2cb_abi.h
+++ b/libo2cb/o2cb_abi.h
@@ -41,4 +41,9 @@
#define O2CB_FORMAT_HEARTBEAT_REGION_ATTR O2CB_FORMAT_HEARTBEAT_REGION "/%s"
#define O2CB_FORMAT_HEARTBEAT_MODE O2CB_FORMAT_HEARTBEAT_DIR "/mode"
+/*
+ * Cluster info flags (ocfs2_cluster_info.ci_stackflags)
+ */
+#define OCFS2_CLUSTER_O2CB_GLOBAL_HEARTBEAT (0x01)
+
#endif /* _O2CB_ABI_H */
diff --git a/libocfs2/dlm.c b/libocfs2/dlm.c
index 848b795..1830970 100644
--- a/libocfs2/dlm.c
+++ b/libocfs2/dlm.c
@@ -110,6 +110,7 @@ errcode_t ocfs2_fill_cluster_desc(ocfs2_filesys *fs,
if (!ocfs2_clusterinfo_valid(sb)) {
desc->c_stack = NULL;
desc->c_cluster = NULL;
+ desc->c_flags = 0;
return 0;
}
@@ -127,16 +128,62 @@ errcode_t ocfs2_fill_cluster_desc(ocfs2_filesys *fs,
OCFS2_STACK_LABEL_LEN);
memcpy(desc->c_cluster, sb->s_cluster_info.ci_cluster,
OCFS2_CLUSTER_NAME_LEN);
+ desc->c_flags = sb->s_cluster_info.ci_stackflags;
return 0;
}
+errcode_t ocfs2_set_cluster_flags(ocfs2_filesys *fs,
+ struct o2cb_cluster_desc *desc)
+{
+ errcode_t ret = 0;
+ struct ocfs2_super_block *sb = OCFS2_RAW_SB(fs->fs_super);
+ int globalhb;
+
+ sb->s_cluster_info.ci_stackflags = 0;
+
+ /* exit if userspace as it does not have any stack flags currently */
+ if (ocfs2_userspace_stack(sb))
+ goto out;
+
+ /* the stack has to be o2cb... if not it is a BUG */
+ if (strcmp(desc->c_stack, OCFS2_CLASSIC_CLUSTER_STACK)) {
+ ret = OCFS2_ET_INVALID_ARGUMENT;
+ goto out;
+ }
+
+ /* exit if not o2cb global hb is not active */
+ ret = o2cb_global_heartbeat_mode(desc->c_cluster, &globalhb);
+ if (ret || !globalhb)
+ goto out;
+
+ /* enable clusterinfo if not yet enabled */
+ if (!ocfs2_clusterinfo_valid(sb))
+ sb->s_feature_incompat |=
+ OCFS2_FEATURE_INCOMPAT_CLUSTERINFO;
+
+ /* set the o2cb cluster flag */
+ sb->s_cluster_info.ci_stackflags |=
+ OCFS2_CLUSTER_O2CB_GLOBAL_HEARTBEAT;
+
+out:
+ return ret;
+}
+
+
errcode_t ocfs2_set_cluster_desc(ocfs2_filesys *fs,
struct o2cb_cluster_desc *desc)
{
errcode_t ret;
struct ocfs2_super_block *sb = OCFS2_RAW_SB(fs->fs_super);
+ if (!(sb->s_feature_incompat & OCFS2_FEATURE_INCOMPAT_CLUSTERINFO)) {
+ if (!desc->c_stack) {
+ ret = OCFS2_ET_INVALID_ARGUMENT;
+ goto out;
+ }
+ }
+
if (desc->c_stack) {
if (!desc->c_stack[0] || !desc->c_cluster ||
!desc->c_cluster[0]) {
@@ -166,6 +213,10 @@ errcode_t ocfs2_set_cluster_desc(ocfs2_filesys *fs,
OCFS2_STACK_LABEL_LEN);
memcpy(sb->s_cluster_info.ci_cluster, desc->c_cluster,
OCFS2_CLUSTER_NAME_LEN);
+
+ ret = ocfs2_set_cluster_flags(fs, desc);
+ if (ret)
+ goto out;
} else {
sb->s_feature_incompat &=
~OCFS2_FEATURE_INCOMPAT_USERSPACE_STACK;
--
1.7.1
More information about the Ocfs2-tools-devel
mailing list