summaryrefslogtreecommitdiffstats
path: root/fs/btrfs/super.c
diff options
context:
space:
mode:
authorJosef Bacik <josef@toxicpanda.com>2023-11-22 12:17:46 -0500
committerDavid Sterba <dsterba@suse.com>2023-12-15 20:27:04 +0100
commit0f85e244dfc5c22cb5e115ccad651df65e6fd68a (patch)
treec92a925cbc0630ff99d72b504c66ba7df35e6bc7 /fs/btrfs/super.c
parent17b3612022fe533e70c0a83ea7634069e5ce33f1 (diff)
downloadlinux-stable-0f85e244dfc5c22cb5e115ccad651df65e6fd68a.tar.gz
linux-stable-0f85e244dfc5c22cb5e115ccad651df65e6fd68a.tar.bz2
linux-stable-0f85e244dfc5c22cb5e115ccad651df65e6fd68a.zip
btrfs: add fs context handling functions
We are going to use the fs context to hold the mount options, so allocate the btrfs_fs_context when we're asked to init the fs context, and free it in the free callback. Reviewed-by: Christian Brauner <brauner@kernel.org> Reviewed-by: Johannes Thumshirn <johannes.thumshirn@wdc.com> Signed-off-by: Josef Bacik <josef@toxicpanda.com> Reviewed-by: David Sterba <dsterba@suse.com> Signed-off-by: David Sterba <dsterba@suse.com>
Diffstat (limited to 'fs/btrfs/super.c')
-rw-r--r--fs/btrfs/super.c36
1 files changed, 35 insertions, 1 deletions
diff --git a/fs/btrfs/super.c b/fs/btrfs/super.c
index 2f981fb87520..78e6e4c30124 100644
--- a/fs/btrfs/super.c
+++ b/fs/btrfs/super.c
@@ -2642,10 +2642,44 @@ static void btrfs_kill_super(struct super_block *sb)
btrfs_free_fs_info(fs_info);
}
-static const struct fs_context_operations btrfs_fs_context_ops __maybe_unused = {
+static void btrfs_free_fs_context(struct fs_context *fc)
+{
+ struct btrfs_fs_context *ctx = fc->fs_private;
+
+ if (!ctx)
+ return;
+
+ kfree(ctx->subvol_name);
+ kfree(ctx);
+}
+
+static const struct fs_context_operations btrfs_fs_context_ops = {
.parse_param = btrfs_parse_param,
+ .free = btrfs_free_fs_context,
};
+static int __maybe_unused btrfs_init_fs_context(struct fs_context *fc)
+{
+ struct btrfs_fs_context *ctx;
+
+ ctx = kzalloc(sizeof(struct btrfs_fs_context), GFP_KERNEL);
+ if (!ctx)
+ return -ENOMEM;
+
+ ctx->thread_pool_size = min_t(unsigned long, num_online_cpus() + 2, 8);
+ ctx->max_inline = BTRFS_DEFAULT_MAX_INLINE;
+ ctx->commit_interval = BTRFS_DEFAULT_COMMIT_INTERVAL;
+ ctx->subvol_objectid = BTRFS_FS_TREE_OBJECTID;
+#ifndef CONFIG_BTRFS_FS_POSIX_ACL
+ ctx->noacl = true;
+#endif
+
+ fc->fs_private = ctx;
+ fc->ops = &btrfs_fs_context_ops;
+
+ return 0;
+}
+
static struct file_system_type btrfs_fs_type = {
.owner = THIS_MODULE,
.name = "btrfs",