[Ocfs2-tools-devel] [PATCH 6/7] tunefs.ocfs2: Turn on and off the extended slot map

Joel Becker joel.becker at oracle.com
Sat Jan 12 23:18:07 PST 2008


Support for the extended slot map.  It can be enabled or disabled.

Signed-off-by: Joel Becker <joel.becker at oracle.com>
---
 tunefs.ocfs2/Makefile         |    9 +++++-
 tunefs.ocfs2/features.c       |   14 +++++++--
 tunefs.ocfs2/format_slotmap.c |   60 +++++++++++++++++++++++++++++++++++++++++
 tunefs.ocfs2/tunefs.c         |   19 +++++++++---
 tunefs.ocfs2/tunefs.h         |    6 +++-
 5 files changed, 98 insertions(+), 10 deletions(-)
 create mode 100644 tunefs.ocfs2/format_slotmap.c

diff --git a/tunefs.ocfs2/Makefile b/tunefs.ocfs2/Makefile
index e062dfb..b4580b3 100644
--- a/tunefs.ocfs2/Makefile
+++ b/tunefs.ocfs2/Makefile
@@ -31,7 +31,14 @@ DEFINES = -DVERSION=\"$(VERSION)\"
 
 MANS = tunefs.ocfs2.8
 
-CFILES = tunefs.c query.c remove_slot.c sparse_file.c features.c
+CFILES =		\
+      tunefs.c		\
+	query.c		\
+	remove_slot.c	\
+	sparse_file.c	\
+	features.c	\
+	format_slotmap.c
+
 HFILES = tunefs.h
 
 OBJS = $(subst .c,.o,$(CFILES))
diff --git a/tunefs.ocfs2/features.c b/tunefs.ocfs2/features.c
index 2208269..36307c8 100644
--- a/tunefs.ocfs2/features.c
+++ b/tunefs.ocfs2/features.c
@@ -1,4 +1,6 @@
-/*
+/* -*- mode: c; c-basic-offset: 8; -*-
+ * vim: noexpandtab sw=8 ts=8 sts=0:
+ *
  * features.c
  *
  * source file for adding or removing features for tunefs.
@@ -33,8 +35,10 @@ extern ocfs2_tune_opts opts;
 #define TUNEFS_COMPAT_CLEAR	0
 #define TUNEFS_RO_COMPAT_SET	OCFS2_FEATURE_RO_COMPAT_UNWRITTEN
 #define TUNEFS_RO_COMPAT_CLEAR	OCFS2_FEATURE_RO_COMPAT_UNWRITTEN
-#define TUNEFS_INCOMPAT_SET	OCFS2_FEATURE_INCOMPAT_SPARSE_ALLOC
-#define TUNEFS_INCOMPAT_CLEAR	OCFS2_FEATURE_INCOMPAT_SPARSE_ALLOC
+#define TUNEFS_INCOMPAT_SET	(OCFS2_FEATURE_INCOMPAT_SPARSE_ALLOC | \
+				 OCFS2_FEATURE_INCOMPAT_EXTENDED_SLOT_MAP)
+#define TUNEFS_INCOMPAT_CLEAR	(OCFS2_FEATURE_INCOMPAT_SPARSE_ALLOC | \
+				 OCFS2_FEATURE_INCOMPAT_EXTENDED_SLOT_MAP)
 
 /*
  * Check whether we can add or remove a feature.
@@ -141,6 +145,10 @@ errcode_t update_feature(ocfs2_filesys *fs)
 	if (opts.set_feature.ro_compat & OCFS2_FEATURE_RO_COMPAT_UNWRITTEN)
 		set_unwritten_extents_flag(fs);
 
+	if ((opts.set_feature.incompat | opts.clear_feature.incompat) &
+	    OCFS2_FEATURE_INCOMPAT_EXTENDED_SLOT_MAP)
+		ret = reformat_slot_map(fs);
+
 bail:
 	return ret;
 }
diff --git a/tunefs.ocfs2/format_slotmap.c b/tunefs.ocfs2/format_slotmap.c
new file mode 100644
index 0000000..99c8f25
--- /dev/null
+++ b/tunefs.ocfs2/format_slotmap.c
@@ -0,0 +1,60 @@
+/* -*- mode: c; c-basic-offset: 8; -*-
+ * vim: noexpandtab sw=8 ts=8 sts=0:
+ *
+ * format_slotmap.c
+ *
+ * Switch between slot map formats.
+ *
+ * Copyright (C) 2007 Oracle.  All rights reserved.
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this program; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 021110-1307, USA.
+ *
+ */
+#include "ocfs2/ocfs2.h"
+
+#include <assert.h>
+
+#include <tunefs.h>
+
+extern ocfs2_tune_opts opts;
+
+errcode_t reformat_slot_map(ocfs2_filesys *fs)
+{
+	errcode_t ret = 0;
+	struct ocfs2_super_block *super = OCFS2_RAW_SB(fs->fs_super);
+	int extended = ocfs2_uses_extended_slot_map(super);
+
+	if (opts.set_feature.incompat &
+	    OCFS2_FEATURE_INCOMPAT_EXTENDED_SLOT_MAP) {
+		if (extended) {
+			printf("Feature \"extended-slotmap\" is already enabled, skipping\n");
+			goto out;
+		}
+		OCFS2_SET_INCOMPAT_FEATURE(super, OCFS2_FEATURE_INCOMPAT_EXTENDED_SLOT_MAP);
+	} else if (opts.clear_feature.incompat &
+		   OCFS2_FEATURE_INCOMPAT_EXTENDED_SLOT_MAP) {
+		if (!extended) {
+			printf("Feature \"extended-slotmap\" is not enabled, skipping\n");
+			goto out;
+		}
+		OCFS2_CLEAR_INCOMPAT_FEATURE(super, OCFS2_FEATURE_INCOMPAT_EXTENDED_SLOT_MAP);
+	}
+
+	ret = ocfs2_format_slot_map(fs);
+
+out:
+	return ret;
+}
diff --git a/tunefs.ocfs2/tunefs.c b/tunefs.ocfs2/tunefs.c
index 03976fe..3e254dd 100644
--- a/tunefs.ocfs2/tunefs.c
+++ b/tunefs.ocfs2/tunefs.c
@@ -1,4 +1,6 @@
-/*
+/* -*- mode: c; c-basic-offset: 8; -*-
+ * vim: noexpandtab sw=8 ts=8 sts=0:
+ *
  * tune.c
  *
  * ocfs2 tune utility
@@ -909,18 +911,25 @@ static void update_mount_type(ocfs2_filesys *fs, int *changed)
 static errcode_t update_slots(ocfs2_filesys *fs, int *changed)
 {
 	errcode_t ret = 0;
+	int orig_slots = OCFS2_RAW_SB(fs->fs_super)->s_max_slots;
 
 	block_signals(SIG_BLOCK);
-	if (opts.num_slots > OCFS2_RAW_SB(fs->fs_super)->s_max_slots)
+	if (opts.num_slots > orig_slots)
 		ret = add_slots(fs);
 	else
 		ret = remove_slots(fs);
-	block_signals(SIG_UNBLOCK);
 	if (ret)
-		return ret;
+		goto unblock;
 
 	OCFS2_RAW_SB(fs->fs_super)->s_max_slots = opts.num_slots;
-	*changed = 1;
+	ret = ocfs2_format_slot_map(fs);
+	if (!ret)
+		*changed = 1;
+	else
+		OCFS2_RAW_SB(fs->fs_super)->s_max_slots = orig_slots;
+
+unblock:
+	block_signals(SIG_UNBLOCK);
 
 	return ret;
 }
diff --git a/tunefs.ocfs2/tunefs.h b/tunefs.ocfs2/tunefs.h
index 4f523b7..887b0a5 100644
--- a/tunefs.ocfs2/tunefs.h
+++ b/tunefs.ocfs2/tunefs.h
@@ -1,4 +1,6 @@
-/*
+/* -*- mode: c; c-basic-offset: 8; -*-
+ * vim: noexpandtab sw=8 ts=8 sts=0:
+ *
  * tune.h
  *
  * ocfs2 tune utility
@@ -105,6 +107,8 @@ errcode_t clear_sparse_file_flag(ocfs2_filesys *fs, char *progname);
 void set_unwritten_extents_flag(ocfs2_filesys *fs);
 void free_clear_ctxt(void);
 
+errcode_t reformat_slot_map(ocfs2_filesys *fs);
+
 errcode_t feature_check(ocfs2_filesys *fs);
 errcode_t update_feature(ocfs2_filesys *fs);
 #endif /* _TUNEFS_H */
-- 
1.5.2.2




More information about the Ocfs2-tools-devel mailing list