Blame SOURCES/0036-fs-ntfs3-Convert-mount-options-to-pointer-in-sbi.patch

Kmods SIG 63c143
From 564c97bdfa39c7d1f331841fb24da6e714693037 Mon Sep 17 00:00:00 2001
Kmods SIG 63c143
From: Kari Argillander <kari.argillander@gmail.com>
Kmods SIG 63c143
Date: Tue, 7 Sep 2021 18:35:51 +0300
Kmods SIG 63c143
Subject: [Backport 564c97bdfa39] src: Convert mount options to pointer in
Kmods SIG 63c143
 sbi
Kmods SIG 63c143
Kmods SIG 63c143
Use pointer to mount options. We want to do this because we will use new
Kmods SIG 63c143
mount api which will benefit that we have spi and mount options in
Kmods SIG 63c143
different allocations. When we remount we do not have to make whole new
Kmods SIG 63c143
spi it is enough that we will allocate just mount options.
Kmods SIG 63c143
Kmods SIG 63c143
Please note that we can do example remount lot cleaner but things will
Kmods SIG 63c143
change in next patch so this should be just functional.
Kmods SIG 63c143
Kmods SIG 63c143
Signed-off-by: Kari Argillander <kari.argillander@gmail.com>
Kmods SIG 63c143
Signed-off-by: Konstantin Komarov <almaz.alexandrovich@paragon-software.com>
Kmods SIG 63c143
---
Kmods SIG 63c143
 src/attrib.c  |  2 +-
Kmods SIG 63c143
 src/dir.c     |  8 ++++----
Kmods SIG 63c143
 src/file.c    |  4 ++--
Kmods SIG 63c143
 src/inode.c   | 12 ++++++------
Kmods SIG 63c143
 src/ntfs_fs.h |  2 +-
Kmods SIG 63c143
 src/super.c   | 31 +++++++++++++++++++------------
Kmods SIG 63c143
 src/xattr.c   |  2 +-
Kmods SIG 63c143
 7 files changed, 34 insertions(+), 27 deletions(-)
Kmods SIG 63c143
Kmods SIG 63c143
diff --git a/src/attrib.c b/src/attrib.c
Kmods SIG 63c143
index 34c4cbf7e29bc49bdb3fa060fd2c235c3fb68536..b1055b284c60323168be99ce69b18e7dbd7bb969 100644
Kmods SIG 63c143
--- a/src/attrib.c
Kmods SIG 63c143
+++ b/src/attrib.c
Kmods SIG 63c143
@@ -529,7 +529,7 @@ int attr_set_size(struct ntfs_inode *ni, enum ATTR_TYPE type,
Kmods SIG 63c143
 		} else if (pre_alloc == -1) {
Kmods SIG 63c143
 			pre_alloc = 0;
Kmods SIG 63c143
 			if (type == ATTR_DATA && !name_len &&
Kmods SIG 63c143
-			    sbi->options.prealloc) {
Kmods SIG 63c143
+			    sbi->options->prealloc) {
Kmods SIG 63c143
 				CLST new_alen2 = bytes_to_cluster(
Kmods SIG 63c143
 					sbi, get_pre_allocated(new_size));
Kmods SIG 63c143
 				pre_alloc = new_alen2 - new_alen;
Kmods SIG 63c143
diff --git a/src/dir.c b/src/dir.c
Kmods SIG 63c143
index 93f6d485564e0103e56ad417f184f1ace0926eea..40440df021eff2a95a87ff7a2af38345a7c40793 100644
Kmods SIG 63c143
--- a/src/dir.c
Kmods SIG 63c143
+++ b/src/dir.c
Kmods SIG 63c143
@@ -24,7 +24,7 @@ int ntfs_utf16_to_nls(struct ntfs_sb_info *sbi, const struct le_str *uni,
Kmods SIG 63c143
 	int ret, uni_len, warn;
Kmods SIG 63c143
 	const __le16 *ip;
Kmods SIG 63c143
 	u8 *op;
Kmods SIG 63c143
-	struct nls_table *nls = sbi->options.nls;
Kmods SIG 63c143
+	struct nls_table *nls = sbi->options->nls;
Kmods SIG 63c143
 
Kmods SIG 63c143
 	static_assert(sizeof(wchar_t) == sizeof(__le16));
Kmods SIG 63c143
 
Kmods SIG 63c143
@@ -186,7 +186,7 @@ int ntfs_nls_to_utf16(struct ntfs_sb_info *sbi, const u8 *name, u32 name_len,
Kmods SIG 63c143
 {
Kmods SIG 63c143
 	int ret, slen;
Kmods SIG 63c143
 	const u8 *end;
Kmods SIG 63c143
-	struct nls_table *nls = sbi->options.nls;
Kmods SIG 63c143
+	struct nls_table *nls = sbi->options->nls;
Kmods SIG 63c143
 	u16 *uname = uni->name;
Kmods SIG 63c143
 
Kmods SIG 63c143
 	static_assert(sizeof(wchar_t) == sizeof(u16));
Kmods SIG 63c143
@@ -301,10 +301,10 @@ static inline int ntfs_filldir(struct ntfs_sb_info *sbi, struct ntfs_inode *ni,
Kmods SIG 63c143
 		return 0;
Kmods SIG 63c143
 
Kmods SIG 63c143
 	/* Skip meta files. Unless option to show metafiles is set. */
Kmods SIG 63c143
-	if (!sbi->options.showmeta && ntfs_is_meta_file(sbi, ino))
Kmods SIG 63c143
+	if (!sbi->options->showmeta && ntfs_is_meta_file(sbi, ino))
Kmods SIG 63c143
 		return 0;
Kmods SIG 63c143
 
Kmods SIG 63c143
-	if (sbi->options.nohidden && (fname->dup.fa & FILE_ATTRIBUTE_HIDDEN))
Kmods SIG 63c143
+	if (sbi->options->nohidden && (fname->dup.fa & FILE_ATTRIBUTE_HIDDEN))
Kmods SIG 63c143
 		return 0;
Kmods SIG 63c143
 
Kmods SIG 63c143
 	name_len = ntfs_utf16_to_nls(sbi, (struct le_str *)&fname->name_len,
Kmods SIG 63c143
diff --git a/src/file.c b/src/file.c
Kmods SIG 63c143
index 424450e77ad52ae550e8de444dc393411d97cde6..fef57141b161747101d6898b8da774a372de5cbf 100644
Kmods SIG 63c143
--- a/src/file.c
Kmods SIG 63c143
+++ b/src/file.c
Kmods SIG 63c143
@@ -737,7 +737,7 @@ int ntfs3_setattr(struct user_namespace *mnt_userns, struct dentry *dentry,
Kmods SIG 63c143
 	umode_t mode = inode->i_mode;
Kmods SIG 63c143
 	int err;
Kmods SIG 63c143
 
Kmods SIG 63c143
-	if (sbi->options.no_acs_rules) {
Kmods SIG 63c143
+	if (sbi->options->no_acs_rules) {
Kmods SIG 63c143
 		/* "No access rules" - Force any changes of time etc. */
Kmods SIG 63c143
 		attr->ia_valid |= ATTR_FORCE;
Kmods SIG 63c143
 		/* and disable for editing some attributes. */
Kmods SIG 63c143
@@ -1185,7 +1185,7 @@ static int ntfs_file_release(struct inode *inode, struct file *file)
Kmods SIG 63c143
 	int err = 0;
Kmods SIG 63c143
 
Kmods SIG 63c143
 	/* If we are last writer on the inode, drop the block reservation. */
Kmods SIG 63c143
-	if (sbi->options.prealloc && ((file->f_mode & FMODE_WRITE) &&
Kmods SIG 63c143
+	if (sbi->options->prealloc && ((file->f_mode & FMODE_WRITE) &&
Kmods SIG 63c143
 				      atomic_read(&inode->i_writecount) == 1)) {
Kmods SIG 63c143
 		ni_lock(ni);
Kmods SIG 63c143
 		down_write(&ni->file.run_lock);
Kmods SIG 63c143
diff --git a/src/inode.c b/src/inode.c
Kmods SIG 63c143
index db2a5a4c38e4d62abfb2c7ca16947cd766982b13..9f740fd301b24f2b1a67da0b78d091b3a3ae4705 100644
Kmods SIG 63c143
--- a/src/inode.c
Kmods SIG 63c143
+++ b/src/inode.c
Kmods SIG 63c143
@@ -49,8 +49,8 @@ static struct inode *ntfs_read_mft(struct inode *inode,
Kmods SIG 63c143
 
Kmods SIG 63c143
 	inode->i_op = NULL;
Kmods SIG 63c143
 	/* Setup 'uid' and 'gid' */
Kmods SIG 63c143
-	inode->i_uid = sbi->options.fs_uid;
Kmods SIG 63c143
-	inode->i_gid = sbi->options.fs_gid;
Kmods SIG 63c143
+	inode->i_uid = sbi->options->fs_uid;
Kmods SIG 63c143
+	inode->i_gid = sbi->options->fs_gid;
Kmods SIG 63c143
 
Kmods SIG 63c143
 	err = mi_init(&ni->mi, sbi, ino);
Kmods SIG 63c143
 	if (err)
Kmods SIG 63c143
@@ -229,7 +229,7 @@ static struct inode *ntfs_read_mft(struct inode *inode,
Kmods SIG 63c143
 			t32 = le16_to_cpu(attr->nres.run_off);
Kmods SIG 63c143
 		}
Kmods SIG 63c143
 
Kmods SIG 63c143
-		mode = S_IFREG | (0777 & sbi->options.fs_fmask_inv);
Kmods SIG 63c143
+		mode = S_IFREG | (0777 & sbi->options->fs_fmask_inv);
Kmods SIG 63c143
 
Kmods SIG 63c143
 		if (!attr->non_res) {
Kmods SIG 63c143
 			ni->ni_flags |= NI_FLAG_RESIDENT;
Kmods SIG 63c143
@@ -272,7 +272,7 @@ static struct inode *ntfs_read_mft(struct inode *inode,
Kmods SIG 63c143
 			goto out;
Kmods SIG 63c143
 
Kmods SIG 63c143
 		mode = sb->s_root
Kmods SIG 63c143
-			       ? (S_IFDIR | (0777 & sbi->options.fs_dmask_inv))
Kmods SIG 63c143
+			       ? (S_IFDIR | (0777 & sbi->options->fs_dmask_inv))
Kmods SIG 63c143
 			       : (S_IFDIR | 0777);
Kmods SIG 63c143
 		goto next_attr;
Kmods SIG 63c143
 
Kmods SIG 63c143
@@ -443,7 +443,7 @@ static struct inode *ntfs_read_mft(struct inode *inode,
Kmods SIG 63c143
 		goto out;
Kmods SIG 63c143
 	}
Kmods SIG 63c143
 
Kmods SIG 63c143
-	if ((sbi->options.sys_immutable &&
Kmods SIG 63c143
+	if ((sbi->options->sys_immutable &&
Kmods SIG 63c143
 	     (std5->fa & FILE_ATTRIBUTE_SYSTEM)) &&
Kmods SIG 63c143
 	    !S_ISFIFO(mode) && !S_ISSOCK(mode) && !S_ISLNK(mode)) {
Kmods SIG 63c143
 		inode->i_flags |= S_IMMUTABLE;
Kmods SIG 63c143
@@ -1244,7 +1244,7 @@ struct inode *ntfs_create_inode(struct user_namespace *mnt_userns,
Kmods SIG 63c143
 		 *	}
Kmods SIG 63c143
 		 */
Kmods SIG 63c143
 	} else if (S_ISREG(mode)) {
Kmods SIG 63c143
-		if (sbi->options.sparse) {
Kmods SIG 63c143
+		if (sbi->options->sparse) {
Kmods SIG 63c143
 			/* Sparsed regular file, cause option 'sparse'. */
Kmods SIG 63c143
 			fa = FILE_ATTRIBUTE_SPARSE_FILE |
Kmods SIG 63c143
 			     FILE_ATTRIBUTE_ARCHIVE;
Kmods SIG 63c143
diff --git a/src/ntfs_fs.h b/src/ntfs_fs.h
Kmods SIG 63c143
index 97e682ebcfb94dd1ad9677ed5ee82bb6a88401a5..98c90c399ee2f447f3ad5f0847c56ca7561f17fb 100644
Kmods SIG 63c143
--- a/src/ntfs_fs.h
Kmods SIG 63c143
+++ b/src/ntfs_fs.h
Kmods SIG 63c143
@@ -279,7 +279,7 @@ struct ntfs_sb_info {
Kmods SIG 63c143
 #endif
Kmods SIG 63c143
 	} compress;
Kmods SIG 63c143
 
Kmods SIG 63c143
-	struct ntfs_mount_options options;
Kmods SIG 63c143
+	struct ntfs_mount_options *options;
Kmods SIG 63c143
 	struct ratelimit_state msg_ratelimit;
Kmods SIG 63c143
 };
Kmods SIG 63c143
 
Kmods SIG 63c143
diff --git a/src/super.c b/src/super.c
Kmods SIG 63c143
index 6cb689605089e2a592143a2b4154a97211f39c6c..0f38203420515b6386bdd51e83c402c431743946 100644
Kmods SIG 63c143
--- a/src/super.c
Kmods SIG 63c143
+++ b/src/super.c
Kmods SIG 63c143
@@ -389,11 +389,11 @@ static int ntfs_remount(struct super_block *sb, int *flags, char *data)
Kmods SIG 63c143
 		return -ENOMEM;
Kmods SIG 63c143
 
Kmods SIG 63c143
 	/* Store  original options. */
Kmods SIG 63c143
-	memcpy(&old_opts, &sbi->options, sizeof(old_opts));
Kmods SIG 63c143
-	clear_mount_options(&sbi->options);
Kmods SIG 63c143
-	memset(&sbi->options, 0, sizeof(sbi->options));
Kmods SIG 63c143
+	memcpy(&old_opts, sbi->options, sizeof(old_opts));
Kmods SIG 63c143
+	clear_mount_options(sbi->options);
Kmods SIG 63c143
+	memset(sbi->options, 0, sizeof(old_opts));
Kmods SIG 63c143
 
Kmods SIG 63c143
-	err = ntfs_parse_options(sb, data, 0, &sbi->options);
Kmods SIG 63c143
+	err = ntfs_parse_options(sb, data, 0, sbi->options);
Kmods SIG 63c143
 	if (err)
Kmods SIG 63c143
 		goto restore_opts;
Kmods SIG 63c143
 
Kmods SIG 63c143
@@ -409,7 +409,7 @@ static int ntfs_remount(struct super_block *sb, int *flags, char *data)
Kmods SIG 63c143
 	sync_filesystem(sb);
Kmods SIG 63c143
 
Kmods SIG 63c143
 	if (ro_rw && (sbi->volume.flags & VOLUME_FLAG_DIRTY) &&
Kmods SIG 63c143
-	    !sbi->options.force) {
Kmods SIG 63c143
+	    !sbi->options->force) {
Kmods SIG 63c143
 		ntfs_warn(sb, "volume is dirty and \"force\" flag is not set!");
Kmods SIG 63c143
 		err = -EINVAL;
Kmods SIG 63c143
 		goto restore_opts;
Kmods SIG 63c143
@@ -422,8 +422,8 @@ static int ntfs_remount(struct super_block *sb, int *flags, char *data)
Kmods SIG 63c143
 	goto out;
Kmods SIG 63c143
 
Kmods SIG 63c143
 restore_opts:
Kmods SIG 63c143
-	clear_mount_options(&sbi->options);
Kmods SIG 63c143
-	memcpy(&sbi->options, &old_opts, sizeof(old_opts));
Kmods SIG 63c143
+	clear_mount_options(sbi->options);
Kmods SIG 63c143
+	memcpy(sbi->options, &old_opts, sizeof(old_opts));
Kmods SIG 63c143
 
Kmods SIG 63c143
 out:
Kmods SIG 63c143
 	kfree(orig_data);
Kmods SIG 63c143
@@ -506,7 +506,8 @@ static noinline void put_ntfs(struct ntfs_sb_info *sbi)
Kmods SIG 63c143
 	xpress_free_decompressor(sbi->compress.xpress);
Kmods SIG 63c143
 	lzx_free_decompressor(sbi->compress.lzx);
Kmods SIG 63c143
 #endif
Kmods SIG 63c143
-	clear_mount_options(&sbi->options);
Kmods SIG 63c143
+	clear_mount_options(sbi->options);
Kmods SIG 63c143
+	kfree(sbi->options);
Kmods SIG 63c143
 
Kmods SIG 63c143
 	kfree(sbi);
Kmods SIG 63c143
 }
Kmods SIG 63c143
@@ -545,7 +546,7 @@ static int ntfs_show_options(struct seq_file *m, struct dentry *root)
Kmods SIG 63c143
 {
Kmods SIG 63c143
 	struct super_block *sb = root->d_sb;
Kmods SIG 63c143
 	struct ntfs_sb_info *sbi = sb->s_fs_info;
Kmods SIG 63c143
-	struct ntfs_mount_options *opts = &sbi->options;
Kmods SIG 63c143
+	struct ntfs_mount_options *opts = sbi->options;
Kmods SIG 63c143
 	struct user_namespace *user_ns = seq_user_ns(m);
Kmods SIG 63c143
 
Kmods SIG 63c143
 	if (opts->uid)
Kmods SIG 63c143
@@ -930,6 +931,12 @@ static int ntfs_fill_super(struct super_block *sb, void *data, int silent)
Kmods SIG 63c143
 	if (!sbi)
Kmods SIG 63c143
 		return -ENOMEM;
Kmods SIG 63c143
 
Kmods SIG 63c143
+	sbi->options = kzalloc(sizeof(struct ntfs_mount_options), GFP_NOFS);
Kmods SIG 63c143
+	if (!sbi->options) {
Kmods SIG 63c143
+		kfree(sbi);
Kmods SIG 63c143
+		return -ENOMEM;
Kmods SIG 63c143
+	}
Kmods SIG 63c143
+
Kmods SIG 63c143
 	sb->s_fs_info = sbi;
Kmods SIG 63c143
 	sbi->sb = sb;
Kmods SIG 63c143
 	sb->s_flags |= SB_NODIRATIME;
Kmods SIG 63c143
@@ -942,7 +949,7 @@ static int ntfs_fill_super(struct super_block *sb, void *data, int silent)
Kmods SIG 63c143
 	ratelimit_state_init(&sbi->msg_ratelimit, DEFAULT_RATELIMIT_INTERVAL,
Kmods SIG 63c143
 			     DEFAULT_RATELIMIT_BURST);
Kmods SIG 63c143
 
Kmods SIG 63c143
-	err = ntfs_parse_options(sb, data, silent, &sbi->options);
Kmods SIG 63c143
+	err = ntfs_parse_options(sb, data, silent, sbi->options);
Kmods SIG 63c143
 	if (err)
Kmods SIG 63c143
 		goto out;
Kmods SIG 63c143
 
Kmods SIG 63c143
@@ -1074,7 +1081,7 @@ static int ntfs_fill_super(struct super_block *sb, void *data, int silent)
Kmods SIG 63c143
 			goto out;
Kmods SIG 63c143
 		}
Kmods SIG 63c143
 	} else if (sbi->volume.flags & VOLUME_FLAG_DIRTY) {
Kmods SIG 63c143
-		if (!is_ro && !sbi->options.force) {
Kmods SIG 63c143
+		if (!is_ro && !sbi->options->force) {
Kmods SIG 63c143
 			ntfs_warn(
Kmods SIG 63c143
 				sb,
Kmods SIG 63c143
 				"volume is dirty and \"force\" flag is not set!");
Kmods SIG 63c143
@@ -1394,7 +1401,7 @@ int ntfs_discard(struct ntfs_sb_info *sbi, CLST lcn, CLST len)
Kmods SIG 63c143
 	if (sbi->flags & NTFS_FLAGS_NODISCARD)
Kmods SIG 63c143
 		return -EOPNOTSUPP;
Kmods SIG 63c143
 
Kmods SIG 63c143
-	if (!sbi->options.discard)
Kmods SIG 63c143
+	if (!sbi->options->discard)
Kmods SIG 63c143
 		return -EOPNOTSUPP;
Kmods SIG 63c143
 
Kmods SIG 63c143
 	lbo = (u64)lcn << sbi->cluster_bits;
Kmods SIG 63c143
diff --git a/src/xattr.c b/src/xattr.c
Kmods SIG 63c143
index b15d532e4a17087b06284d82965c21224f1d4f35..ac4b37bf8832a51b9e32b7c4feb6f1c762d5b271 100644
Kmods SIG 63c143
--- a/src/xattr.c
Kmods SIG 63c143
+++ b/src/xattr.c
Kmods SIG 63c143
@@ -769,7 +769,7 @@ int ntfs_acl_chmod(struct user_namespace *mnt_userns, struct inode *inode)
Kmods SIG 63c143
 int ntfs_permission(struct user_namespace *mnt_userns, struct inode *inode,
Kmods SIG 63c143
 		    int mask)
Kmods SIG 63c143
 {
Kmods SIG 63c143
-	if (ntfs_sb(inode->i_sb)->options.no_acs_rules) {
Kmods SIG 63c143
+	if (ntfs_sb(inode->i_sb)->options->no_acs_rules) {
Kmods SIG 63c143
 		/* "No access rules" mode - Allow all changes. */
Kmods SIG 63c143
 		return 0;
Kmods SIG 63c143
 	}
Kmods SIG 63c143
-- 
Kmods SIG 63c143
2.31.1
Kmods SIG 63c143