Blame SOURCES/xfsprogs-5.10.0-mkfs-enable-the-inode-btree-counter-feature.patch

5d5cbe
From 9eb0d6eb9066daa621e710139c8c8d50fedbabcf Mon Sep 17 00:00:00 2001
5d5cbe
From: "Darrick J. Wong" <darrick.wong@oracle.com>
5d5cbe
Date: Fri, 20 Nov 2020 17:03:27 -0500
5d5cbe
Subject: [PATCH] mkfs: enable the inode btree counter feature
5d5cbe
5d5cbe
Teach mkfs how to enable the inode btree counter feature.
5d5cbe
5d5cbe
Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
5d5cbe
Reviewed-by: Brian Foster <bfoster@redhat.com>
5d5cbe
Signed-off-by: Eric Sandeen <sandeen@sandeen.net>
5d5cbe
---
5d5cbe
5d5cbe
diff --git a/man/man8/mkfs.xfs.8 b/man/man8/mkfs.xfs.8
5d5cbe
index 9d6f315..45b150f 100644
5d5cbe
--- a/man/man8/mkfs.xfs.8
5d5cbe
+++ b/man/man8/mkfs.xfs.8
5d5cbe
@@ -188,6 +188,21 @@ option set. When the option
5d5cbe
 .B \-m crc=0
5d5cbe
 is used, the free inode btree feature is not supported and is disabled.
5d5cbe
 .TP
5d5cbe
+.BI inobtcount= value
5d5cbe
+This option causes the filesystem to record the number of blocks used by
5d5cbe
+the inode btree and the free inode btree.
5d5cbe
+This can be used to reduce mount times when the free inode btree is enabled.
5d5cbe
+.IP
5d5cbe
+By default,
5d5cbe
+.B mkfs.xfs
5d5cbe
+will not enable this option.
5d5cbe
+This feature is only available for filesystems created with the (default)
5d5cbe
+.B \-m finobt=1
5d5cbe
+option set.
5d5cbe
+When the option
5d5cbe
+.B \-m finobt=0
5d5cbe
+is used, the inode btree counter feature is not supported and is disabled.
5d5cbe
+.TP
5d5cbe
 .BI uuid= value
5d5cbe
 Use the given value as the filesystem UUID for the newly created filesystem.
5d5cbe
 The default is to generate a random UUID.
5d5cbe
diff --git a/mkfs/xfs_mkfs.c b/mkfs/xfs_mkfs.c
5d5cbe
index 16819d8..87f15f4 100644
5d5cbe
--- a/mkfs/xfs_mkfs.c
5d5cbe
+++ b/mkfs/xfs_mkfs.c
5d5cbe
@@ -117,6 +117,7 @@ enum {
5d5cbe
 	M_UUID,
5d5cbe
 	M_RMAPBT,
5d5cbe
 	M_REFLINK,
5d5cbe
+	M_INOBTCNT,
5d5cbe
 	M_MAX_OPTS,
5d5cbe
 };
5d5cbe
 
5d5cbe
@@ -651,6 +652,7 @@ static struct opt_params mopts = {
5d5cbe
 		[M_UUID] = "uuid",
5d5cbe
 		[M_RMAPBT] = "rmapbt",
5d5cbe
 		[M_REFLINK] = "reflink",
5d5cbe
+		[M_INOBTCNT] = "inobtcount",
5d5cbe
 	},
5d5cbe
 	.subopt_params = {
5d5cbe
 		{ .index = M_CRC,
5d5cbe
@@ -681,6 +683,12 @@ static struct opt_params mopts = {
5d5cbe
 		  .maxval = 1,
5d5cbe
 		  .defaultval = 1,
5d5cbe
 		},
5d5cbe
+		{ .index = M_INOBTCNT,
5d5cbe
+		  .conflicts = { { NULL, LAST_CONFLICT } },
5d5cbe
+		  .minval = 0,
5d5cbe
+		  .maxval = 1,
5d5cbe
+		  .defaultval = 1,
5d5cbe
+		},
5d5cbe
 	},
5d5cbe
 };
5d5cbe
 
5d5cbe
@@ -731,6 +739,7 @@ struct sb_feat_args {
5d5cbe
 	bool	spinodes;		/* XFS_SB_FEAT_INCOMPAT_SPINODES */
5d5cbe
 	bool	rmapbt;			/* XFS_SB_FEAT_RO_COMPAT_RMAPBT */
5d5cbe
 	bool	reflink;		/* XFS_SB_FEAT_RO_COMPAT_REFLINK */
5d5cbe
+	bool	inobtcnt;		/* XFS_SB_FEAT_RO_COMPAT_INOBTCNT */
5d5cbe
 	bool	nodalign;
5d5cbe
 	bool	nortalign;
5d5cbe
 };
5d5cbe
@@ -853,7 +862,8 @@ usage( void )
5d5cbe
 {
5d5cbe
 	fprintf(stderr, _("Usage: %s\n\
5d5cbe
 /* blocksize */		[-b size=num]\n\
5d5cbe
-/* metadata */		[-m crc=0|1,finobt=0|1,uuid=xxx,rmapbt=0|1,reflink=0|1]\n\
5d5cbe
+/* metadata */		[-m crc=0|1,finobt=0|1,uuid=xxx,rmapbt=0|1,reflink=0|1,\n\
5d5cbe
+			    inobtcnt=0|1]\n\
5d5cbe
 /* data subvol */	[-d agcount=n,agsize=n,file,name=xxx,size=num,\n\
5d5cbe
 			    (sunit=value,swidth=value|su=num,sw=num|noalign),\n\
5d5cbe
 			    sectsize=num\n\
5d5cbe
@@ -1607,6 +1617,9 @@ meta_opts_parser(
5d5cbe
 	case M_REFLINK:
5d5cbe
 		cli->sb_feat.reflink = getnum(value, opts, subopt);
5d5cbe
 		break;
5d5cbe
+	case M_INOBTCNT:
5d5cbe
+		cli->sb_feat.inobtcnt = getnum(value, opts, subopt);
5d5cbe
+		break;
5d5cbe
 	default:
5d5cbe
 		return -EINVAL;
5d5cbe
 	}
5d5cbe
@@ -2037,6 +2050,22 @@ _("reflink not supported without CRC support\n"));
5d5cbe
 			usage();
5d5cbe
 		}
5d5cbe
 		cli->sb_feat.reflink = false;
5d5cbe
+
5d5cbe
+		if (cli->sb_feat.inobtcnt && cli_opt_set(&mopts, M_INOBTCNT)) {
5d5cbe
+			fprintf(stderr,
5d5cbe
+_("inode btree counters not supported without CRC support\n"));
5d5cbe
+			usage();
5d5cbe
+		}
5d5cbe
+		cli->sb_feat.inobtcnt = false;
5d5cbe
+	}
5d5cbe
+
5d5cbe
+	if (!cli->sb_feat.finobt) {
5d5cbe
+		if (cli->sb_feat.inobtcnt && cli_opt_set(&mopts, M_INOBTCNT)) {
5d5cbe
+			fprintf(stderr,
5d5cbe
+_("inode btree counters not supported without finobt support\n"));
5d5cbe
+			usage();
5d5cbe
+		}
5d5cbe
+		cli->sb_feat.inobtcnt = false;
5d5cbe
 	}
5d5cbe
 
5d5cbe
 	if ((cli->fsx.fsx_xflags & FS_XFLAG_COWEXTSIZE) &&
5d5cbe
@@ -3002,6 +3031,8 @@ sb_set_features(
5d5cbe
 		sbp->sb_features_ro_compat |= XFS_SB_FEAT_RO_COMPAT_RMAPBT;
5d5cbe
 	if (fp->reflink)
5d5cbe
 		sbp->sb_features_ro_compat |= XFS_SB_FEAT_RO_COMPAT_REFLINK;
5d5cbe
+	if (fp->inobtcnt)
5d5cbe
+		sbp->sb_features_ro_compat |= XFS_SB_FEAT_RO_COMPAT_INOBTCNT;
5d5cbe
 
5d5cbe
 	/*
5d5cbe
 	 * Sparse inode chunk support has two main inode alignment requirements.
5d5cbe
@@ -3917,6 +3948,7 @@ main(
5d5cbe
 			.spinodes = true,
5d5cbe
 			.rmapbt = false,
5d5cbe
 			.reflink = true,
5d5cbe
+			.inobtcnt = false,
5d5cbe
 			.parent_pointers = false,
5d5cbe
 			.nodalign = false,
5d5cbe
 			.nortalign = false,