]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
erofs: clean up erofs_register_sysfs()
authorGao Xiang <hsiangkao@linux.alibaba.com>
Wed, 28 Aug 2024 09:52:32 +0000 (17:52 +0800)
committerGao Xiang <hsiangkao@linux.alibaba.com>
Mon, 9 Sep 2024 16:46:34 +0000 (00:46 +0800)
After commit 684b290abc77 ("erofs: add support for
FS_IOC_GETFSSYSFSPATH"), `sb->s_sysfs_name` is now valid.

Just use it to get rid of duplicated logic.

Reviewed-by: Sandeep Dhavale <dhavale@google.com>
Reviewed-by: Chao Yu <chao@kernel.org>
Signed-off-by: Gao Xiang <hsiangkao@linux.alibaba.com>
Link: https://lore.kernel.org/r/20240828095232.571946-1-hsiangkao@linux.alibaba.com
fs/erofs/super.c
fs/erofs/sysfs.c

index 6cb5c8916174be4ead0500d421da82df985cf5f6..aae3fd15899a990eb9faa64de58ff8cdac41189d 100644 (file)
@@ -644,7 +644,6 @@ static int erofs_fc_fill_super(struct super_block *sb, struct fs_context *fc)
                sb->s_flags |= SB_POSIXACL;
        else
                sb->s_flags &= ~SB_POSIXACL;
-       erofs_set_sysfs_name(sb);
 
 #ifdef CONFIG_EROFS_FS_ZIP
        xa_init(&sbi->managed_pslots);
@@ -682,6 +681,7 @@ static int erofs_fc_fill_super(struct super_block *sb, struct fs_context *fc)
        if (err)
                return err;
 
+       erofs_set_sysfs_name(sb);
        err = erofs_register_sysfs(sb);
        if (err)
                return err;
index 435e515c0792012fb0de8c5268c7f7042cedf811..63cffd0fd26195ac4f62e22f07ac273b97a88b4d 100644 (file)
@@ -205,34 +205,16 @@ static struct kobject erofs_feat = {
 int erofs_register_sysfs(struct super_block *sb)
 {
        struct erofs_sb_info *sbi = EROFS_SB(sb);
-       char *name;
-       char *str = NULL;
        int err;
 
-       if (erofs_is_fscache_mode(sb)) {
-               if (sbi->domain_id) {
-                       str = kasprintf(GFP_KERNEL, "%s,%s", sbi->domain_id,
-                                       sbi->fsid);
-                       if (!str)
-                               return -ENOMEM;
-                       name = str;
-               } else {
-                       name = sbi->fsid;
-               }
-       } else {
-               name = sb->s_id;
-       }
        sbi->s_kobj.kset = &erofs_root;
        init_completion(&sbi->s_kobj_unregister);
-       err = kobject_init_and_add(&sbi->s_kobj, &erofs_sb_ktype, NULL, "%s", name);
-       kfree(str);
-       if (err)
-               goto put_sb_kobj;
-       return 0;
-
-put_sb_kobj:
-       kobject_put(&sbi->s_kobj);
-       wait_for_completion(&sbi->s_kobj_unregister);
+       err = kobject_init_and_add(&sbi->s_kobj, &erofs_sb_ktype, NULL, "%s",
+                                  sb->s_sysfs_name);
+       if (err) {
+               kobject_put(&sbi->s_kobj);
+               wait_for_completion(&sbi->s_kobj_unregister);
+       }
        return err;
 }