mutex_unlock(&sbi->s_lock);
 
        unload_nls(sbi->nls_io);
-       exfat_free_iocharset(sbi);
        exfat_free_upcase_table(sbi);
-       kfree(sbi);
 }
 
 static int exfat_sync_fs(struct super_block *sb, int wait)
 
 check_nls_io:
        unload_nls(sbi->nls_io);
-       exfat_free_iocharset(sbi);
-       sb->s_fs_info = NULL;
-       kfree(sbi);
        return err;
 }
 
        return get_tree_bdev(fc, exfat_fill_super);
 }
 
+static void exfat_free_sbi(struct exfat_sb_info *sbi)
+{
+       exfat_free_iocharset(sbi);
+       kfree(sbi);
+}
+
 static void exfat_free(struct fs_context *fc)
 {
        struct exfat_sb_info *sbi = fc->s_fs_info;
 
-       if (sbi) {
-               exfat_free_iocharset(sbi);
-               kfree(sbi);
-       }
+       if (sbi)
+               exfat_free_sbi(sbi);
 }
 
 static int exfat_reconfigure(struct fs_context *fc)
        return 0;
 }
 
+static void exfat_kill_sb(struct super_block *sb)
+{
+       struct exfat_sb_info *sbi = sb->s_fs_info;
+
+       kill_block_super(sb);
+       if (sbi)
+               exfat_free_sbi(sbi);
+}
+
 static struct file_system_type exfat_fs_type = {
        .owner                  = THIS_MODULE,
        .name                   = "exfat",
        .init_fs_context        = exfat_init_fs_context,
        .parameters             = exfat_parameters,
-       .kill_sb                = kill_block_super,
+       .kill_sb                = exfat_kill_sb,
        .fs_flags               = FS_REQUIRES_DEV,
 };