* invalidate intermediate page cache borrowed from meta inode
         * which are used for migration of encrypted inode's blocks.
         */
-       if (f2fs_sb_has_encrypt(sbi->sb))
+       if (f2fs_sb_has_encrypt(sbi))
                invalidate_mapping_pages(META_MAPPING(sbi),
                                MAIN_BLKADDR(sbi), MAX_BLKADDR(sbi) - 1);
 
 
 #define F2FS_FEATURE_VERITY            0x0400  /* reserved */
 #define F2FS_FEATURE_SB_CHKSUM         0x0800
 
-#define F2FS_HAS_FEATURE(sb, mask)                                     \
-       ((F2FS_SB(sb)->raw_super->feature & cpu_to_le32(mask)) != 0)
-#define F2FS_SET_FEATURE(sb, mask)                                     \
-       (F2FS_SB(sb)->raw_super->feature |= cpu_to_le32(mask))
-#define F2FS_CLEAR_FEATURE(sb, mask)                                   \
-       (F2FS_SB(sb)->raw_super->feature &= ~cpu_to_le32(mask))
+#define __F2FS_HAS_FEATURE(raw_super, mask)                            \
+       ((raw_super->feature & cpu_to_le32(mask)) != 0)
+#define F2FS_HAS_FEATURE(sbi, mask)    __F2FS_HAS_FEATURE(sbi->raw_super, mask)
+#define F2FS_SET_FEATURE(sbi, mask)                                    \
+       (sbi->raw_super->feature |= cpu_to_le32(mask))
+#define F2FS_CLEAR_FEATURE(sbi, mask)                                  \
+       (sbi->raw_super->feature &= ~cpu_to_le32(mask))
 
 /*
  * Default values for user and/or group using reserved blocks
 }
 
 #define F2FS_FEATURE_FUNCS(name, flagname) \
-static inline int f2fs_sb_has_##name(struct super_block *sb) \
+static inline int f2fs_sb_has_##name(struct f2fs_sb_info *sbi) \
 { \
-       return F2FS_HAS_FEATURE(sb, F2FS_FEATURE_##flagname); \
+       return F2FS_HAS_FEATURE(sbi, F2FS_FEATURE_##flagname); \
 }
 
 F2FS_FEATURE_FUNCS(encrypt, ENCRYPT);
 
 static inline bool f2fs_hw_should_discard(struct f2fs_sb_info *sbi)
 {
-       return f2fs_sb_has_blkzoned(sbi->sb);
+       return f2fs_sb_has_blkzoned(sbi);
 }
 
 static inline bool f2fs_hw_support_discard(struct f2fs_sb_info *sbi)
         * for blkzoned device, fallback direct IO to buffered IO, so
         * all IOs can be serialized by log-structured write.
         */
-       if (f2fs_sb_has_blkzoned(sbi->sb))
+       if (f2fs_sb_has_blkzoned(sbi))
                return true;
        if (test_opt(sbi, LFS) && (rw == WRITE) &&
                                block_unaligned_IO(inode, iocb, iter))
 static inline bool is_journalled_quota(struct f2fs_sb_info *sbi)
 {
 #ifdef CONFIG_QUOTA
-       if (f2fs_sb_has_quota_ino(sbi->sb))
+       if (f2fs_sb_has_quota_ino(sbi))
                return true;
        if (F2FS_OPTION(sbi).s_qf_names[USRQUOTA] ||
                F2FS_OPTION(sbi).s_qf_names[GRPQUOTA] ||
 
        unsigned int flags;
 
        if (f2fs_has_extra_attr(inode) &&
-                       f2fs_sb_has_inode_crtime(inode->i_sb) &&
+                       f2fs_sb_has_inode_crtime(F2FS_I_SB(inode)) &&
                        F2FS_FITS_IN_INODE(ri, fi->i_extra_isize, i_crtime)) {
                stat->result_mask |= STATX_BTIME;
                stat->btime.tv_sec = fi->i_crtime.tv_sec;
 {
        struct inode *inode = file_inode(filp);
 
-       if (!f2fs_sb_has_encrypt(inode->i_sb))
+       if (!f2fs_sb_has_encrypt(F2FS_I_SB(inode)))
                return -EOPNOTSUPP;
 
        f2fs_update_time(F2FS_I_SB(inode), REQ_TIME);
 
 static int f2fs_ioc_get_encryption_policy(struct file *filp, unsigned long arg)
 {
-       if (!f2fs_sb_has_encrypt(file_inode(filp)->i_sb))
+       if (!f2fs_sb_has_encrypt(F2FS_I_SB(file_inode(filp))))
                return -EOPNOTSUPP;
        return fscrypt_ioctl_get_policy(filp, (void __user *)arg);
 }
        struct f2fs_sb_info *sbi = F2FS_I_SB(inode);
        int err;
 
-       if (!f2fs_sb_has_encrypt(inode->i_sb))
+       if (!f2fs_sb_has_encrypt(sbi))
                return -EOPNOTSUPP;
 
        err = mnt_want_write_file(filp);
        struct inode *inode = file_inode(filp);
        struct f2fs_inode_info *fi = F2FS_I(inode);
        struct f2fs_sb_info *sbi = F2FS_I_SB(inode);
-       struct super_block *sb = sbi->sb;
        struct page *ipage;
        kprojid_t kprojid;
        int err;
 
-       if (!f2fs_sb_has_project_quota(sb)) {
+       if (!f2fs_sb_has_project_quota(sbi)) {
                if (projid != F2FS_DEF_PROJID)
                        return -EOPNOTSUPP;
                else
        fa.fsx_xflags = f2fs_iflags_to_xflags(fi->i_flags &
                                F2FS_FL_USER_VISIBLE);
 
-       if (f2fs_sb_has_project_quota(inode->i_sb))
+       if (f2fs_sb_has_project_quota(F2FS_I_SB(inode)))
                fa.fsx_projid = (__u32)from_kprojid(&init_user_ns,
                                                        fi->i_projid);
 
 
 {
        struct f2fs_inode *ri = &F2FS_NODE(page)->i;
 
-       if (!f2fs_sb_has_inode_chksum(sbi->sb))
+       if (!f2fs_sb_has_inode_chksum(sbi))
                return false;
 
        if (!IS_INODE(page) || !(ri->i_inline & F2FS_EXTRA_ATTR))
                return false;
        }
 
-       if (f2fs_sb_has_flexible_inline_xattr(sbi->sb)
+       if (f2fs_sb_has_flexible_inline_xattr(sbi)
                        && !f2fs_has_extra_attr(inode)) {
                set_sbi_flag(sbi, SBI_NEED_FSCK);
                f2fs_msg(sbi->sb, KERN_WARNING,
        }
 
        if (f2fs_has_extra_attr(inode) &&
-                       !f2fs_sb_has_extra_attr(sbi->sb)) {
+                       !f2fs_sb_has_extra_attr(sbi)) {
                set_sbi_flag(sbi, SBI_NEED_FSCK);
                f2fs_msg(sbi->sb, KERN_WARNING,
                        "%s: inode (ino=%lx) is with extra_attr, "
        fi->i_extra_isize = f2fs_has_extra_attr(inode) ?
                                        le16_to_cpu(ri->i_extra_isize) : 0;
 
-       if (f2fs_sb_has_flexible_inline_xattr(sbi->sb)) {
+       if (f2fs_sb_has_flexible_inline_xattr(sbi)) {
                fi->i_inline_xattr_size = le16_to_cpu(ri->i_inline_xattr_size);
        } else if (f2fs_has_inline_xattr(inode) ||
                                f2fs_has_inline_dentry(inode)) {
        if (fi->i_flags & F2FS_PROJINHERIT_FL)
                set_inode_flag(inode, FI_PROJ_INHERIT);
 
-       if (f2fs_has_extra_attr(inode) && f2fs_sb_has_project_quota(sbi->sb) &&
+       if (f2fs_has_extra_attr(inode) && f2fs_sb_has_project_quota(sbi) &&
                        F2FS_FITS_IN_INODE(ri, fi->i_extra_isize, i_projid))
                i_projid = (projid_t)le32_to_cpu(ri->i_projid);
        else
                i_projid = F2FS_DEF_PROJID;
        fi->i_projid = make_kprojid(&init_user_ns, i_projid);
 
-       if (f2fs_has_extra_attr(inode) && f2fs_sb_has_inode_crtime(sbi->sb) &&
+       if (f2fs_has_extra_attr(inode) && f2fs_sb_has_inode_crtime(sbi) &&
                        F2FS_FITS_IN_INODE(ri, fi->i_extra_isize, i_crtime)) {
                fi->i_crtime.tv_sec = le64_to_cpu(ri->i_crtime);
                fi->i_crtime.tv_nsec = le32_to_cpu(ri->i_crtime_nsec);
        if (f2fs_has_extra_attr(inode)) {
                ri->i_extra_isize = cpu_to_le16(F2FS_I(inode)->i_extra_isize);
 
-               if (f2fs_sb_has_flexible_inline_xattr(F2FS_I_SB(inode)->sb))
+               if (f2fs_sb_has_flexible_inline_xattr(F2FS_I_SB(inode)))
                        ri->i_inline_xattr_size =
                                cpu_to_le16(F2FS_I(inode)->i_inline_xattr_size);
 
-               if (f2fs_sb_has_project_quota(F2FS_I_SB(inode)->sb) &&
+               if (f2fs_sb_has_project_quota(F2FS_I_SB(inode)) &&
                        F2FS_FITS_IN_INODE(ri, F2FS_I(inode)->i_extra_isize,
                                                                i_projid)) {
                        projid_t i_projid;
                        ri->i_projid = cpu_to_le32(i_projid);
                }
 
-               if (f2fs_sb_has_inode_crtime(F2FS_I_SB(inode)->sb) &&
+               if (f2fs_sb_has_inode_crtime(F2FS_I_SB(inode)) &&
                        F2FS_FITS_IN_INODE(ri, F2FS_I(inode)->i_extra_isize,
                                                                i_crtime)) {
                        ri->i_crtime =
 
                goto fail;
        }
 
-       if (f2fs_sb_has_project_quota(sbi->sb) &&
+       if (f2fs_sb_has_project_quota(sbi) &&
                (F2FS_I(dir)->i_flags & F2FS_PROJINHERIT_FL))
                F2FS_I(inode)->i_projid = F2FS_I(dir)->i_projid;
        else
                                f2fs_may_encrypt(inode))
                f2fs_set_encrypted_inode(inode);
 
-       if (f2fs_sb_has_extra_attr(sbi->sb)) {
+       if (f2fs_sb_has_extra_attr(sbi)) {
                set_inode_flag(inode, FI_EXTRA_ATTR);
                F2FS_I(inode)->i_extra_isize = F2FS_TOTAL_EXTRA_ATTR_SIZE;
        }
        if (f2fs_may_inline_dentry(inode))
                set_inode_flag(inode, FI_INLINE_DENTRY);
 
-       if (f2fs_sb_has_flexible_inline_xattr(sbi->sb)) {
+       if (f2fs_sb_has_flexible_inline_xattr(sbi)) {
                f2fs_bug_on(sbi, !f2fs_has_extra_attr(inode));
                if (f2fs_has_inline_xattr(inode))
                        xattr_size = F2FS_OPTION(sbi).inline_xattr_size;
 
        if (dst->i_inline & F2FS_EXTRA_ATTR) {
                dst->i_extra_isize = src->i_extra_isize;
 
-               if (f2fs_sb_has_flexible_inline_xattr(sbi->sb) &&
+               if (f2fs_sb_has_flexible_inline_xattr(sbi) &&
                        F2FS_FITS_IN_INODE(src, le16_to_cpu(src->i_extra_isize),
                                                        i_inline_xattr_size))
                        dst->i_inline_xattr_size = src->i_inline_xattr_size;
 
-               if (f2fs_sb_has_project_quota(sbi->sb) &&
+               if (f2fs_sb_has_project_quota(sbi) &&
                        F2FS_FITS_IN_INODE(src, le16_to_cpu(src->i_extra_isize),
                                                                i_projid))
                        dst->i_projid = src->i_projid;
 
-               if (f2fs_sb_has_inode_crtime(sbi->sb) &&
+               if (f2fs_sb_has_inode_crtime(sbi) &&
                        F2FS_FITS_IN_INODE(src, le16_to_cpu(src->i_extra_isize),
                                                        i_crtime_nsec)) {
                        dst->i_crtime = src->i_crtime;
 
        i_gid_write(inode, le32_to_cpu(raw->i_gid));
 
        if (raw->i_inline & F2FS_EXTRA_ATTR) {
-               if (f2fs_sb_has_project_quota(F2FS_I_SB(inode)->sb) &&
+               if (f2fs_sb_has_project_quota(F2FS_I_SB(inode)) &&
                        F2FS_FITS_IN_INODE(raw, le16_to_cpu(raw->i_extra_isize),
                                                                i_projid)) {
                        projid_t i_projid;
 
                struct block_device *bdev, block_t blkstart, block_t blklen)
 {
 #ifdef CONFIG_BLK_DEV_ZONED
-       if (f2fs_sb_has_blkzoned(sbi->sb) &&
+       if (f2fs_sb_has_blkzoned(sbi) &&
                                bdev_zoned_model(bdev) != BLK_ZONED_NONE)
                return __f2fs_issue_discard_zone(sbi, bdev, blkstart, blklen);
 #endif
                                        sbi->blocks_per_seg, cur_pos);
                        len = next_pos - cur_pos;
 
-                       if (f2fs_sb_has_blkzoned(sbi->sb) ||
+                       if (f2fs_sb_has_blkzoned(sbi) ||
                            (force && len < cpc->trim_minlen))
                                goto skip;
 
 
                        "quota options when quota turned on");
                return -EINVAL;
        }
-       if (f2fs_sb_has_quota_ino(sb)) {
+       if (f2fs_sb_has_quota_ino(sbi)) {
                f2fs_msg(sb, KERN_INFO,
                        "QUOTA feature is enabled, so ignore qf_name");
                return 0;
         * 'grpquota' mount options are allowed even without quota feature
         * to support legacy quotas in quota files.
         */
-       if (test_opt(sbi, PRJQUOTA) && !f2fs_sb_has_project_quota(sbi->sb)) {
+       if (test_opt(sbi, PRJQUOTA) && !f2fs_sb_has_project_quota(sbi)) {
                f2fs_msg(sbi->sb, KERN_ERR, "Project quota feature not enabled. "
                         "Cannot enable project quota enforcement.");
                return -1;
                }
        }
 
-       if (f2fs_sb_has_quota_ino(sbi->sb) && F2FS_OPTION(sbi).s_jquota_fmt) {
+       if (f2fs_sb_has_quota_ino(sbi) && F2FS_OPTION(sbi).s_jquota_fmt) {
                f2fs_msg(sbi->sb, KERN_INFO,
                        "QUOTA feature is enabled, so ignore jquota_fmt");
                F2FS_OPTION(sbi).s_jquota_fmt = 0;
                        set_opt(sbi, DISCARD);
                        break;
                case Opt_nodiscard:
-                       if (f2fs_sb_has_blkzoned(sb)) {
+                       if (f2fs_sb_has_blkzoned(sbi)) {
                                f2fs_msg(sb, KERN_WARNING,
                                        "discard is required for zoned block devices");
                                return -EINVAL;
                                return -ENOMEM;
                        if (strlen(name) == 8 &&
                                        !strncmp(name, "adaptive", 8)) {
-                               if (f2fs_sb_has_blkzoned(sb)) {
+                               if (f2fs_sb_has_blkzoned(sbi)) {
                                        f2fs_msg(sb, KERN_WARNING,
                                                 "adaptive mode is not allowed with "
                                                 "zoned block device feature");
                        break;
                case Opt_test_dummy_encryption:
 #ifdef CONFIG_F2FS_FS_ENCRYPTION
-                       if (!f2fs_sb_has_encrypt(sb)) {
+                       if (!f2fs_sb_has_encrypt(sbi)) {
                                f2fs_msg(sb, KERN_ERR, "Encrypt feature is off");
                                return -EINVAL;
                        }
        if (f2fs_check_quota_options(sbi))
                return -EINVAL;
 #else
-       if (f2fs_sb_has_quota_ino(sbi->sb) && !f2fs_readonly(sbi->sb)) {
+       if (f2fs_sb_has_quota_ino(sbi) && !f2fs_readonly(sbi->sb)) {
                f2fs_msg(sbi->sb, KERN_INFO,
                         "Filesystem with quota feature cannot be mounted RDWR "
                         "without CONFIG_QUOTA");
                return -EINVAL;
        }
-       if (f2fs_sb_has_project_quota(sbi->sb) && !f2fs_readonly(sbi->sb)) {
+       if (f2fs_sb_has_project_quota(sbi) && !f2fs_readonly(sbi->sb)) {
                f2fs_msg(sb, KERN_ERR,
                        "Filesystem with project quota feature cannot be "
                        "mounted RDWR without CONFIG_QUOTA");
        }
 
        if (test_opt(sbi, INLINE_XATTR_SIZE)) {
-               if (!f2fs_sb_has_extra_attr(sb) ||
-                       !f2fs_sb_has_flexible_inline_xattr(sb)) {
+               if (!f2fs_sb_has_extra_attr(sbi) ||
+                       !f2fs_sb_has_flexible_inline_xattr(sbi)) {
                        f2fs_msg(sb, KERN_ERR,
                                        "extra_attr or flexible_inline_xattr "
                                        "feature is off");
        sbi->sb->s_flags |= SB_LAZYTIME;
        set_opt(sbi, FLUSH_MERGE);
        set_opt(sbi, DISCARD);
-       if (f2fs_sb_has_blkzoned(sbi->sb))
+       if (f2fs_sb_has_blkzoned(sbi))
                set_opt_mode(sbi, F2FS_MOUNT_LFS);
        else
                set_opt_mode(sbi, F2FS_MOUNT_ADAPTIVE);
                sb->s_flags &= ~SB_RDONLY;
                if (sb_any_quota_suspended(sb)) {
                        dquot_resume(sb, -1);
-               } else if (f2fs_sb_has_quota_ino(sb)) {
+               } else if (f2fs_sb_has_quota_ino(sbi)) {
                        err = f2fs_enable_quotas(sb);
                        if (err)
                                goto restore_opts;
        int enabled = 0;
        int i, err;
 
-       if (f2fs_sb_has_quota_ino(sbi->sb) && rdonly) {
+       if (f2fs_sb_has_quota_ino(sbi) && rdonly) {
                err = f2fs_enable_quotas(sbi->sb);
                if (err) {
                        f2fs_msg(sbi->sb, KERN_ERR,
        unsigned long qf_inum;
        int err;
 
-       BUG_ON(!f2fs_sb_has_quota_ino(sb));
+       BUG_ON(!f2fs_sb_has_quota_ino(F2FS_SB(sb)));
 
        qf_inum = f2fs_qf_ino(sb, type);
        if (!qf_inum)
                goto out_put;
 
        err = dquot_quota_off(sb, type);
-       if (err || f2fs_sb_has_quota_ino(sb))
+       if (err || f2fs_sb_has_quota_ino(F2FS_SB(sb)))
                goto out_put;
 
        inode_lock(inode);
         * if LOST_FOUND feature is enabled.
         *
         */
-       if (f2fs_sb_has_lost_found(sbi->sb) &&
+       if (f2fs_sb_has_lost_found(sbi) &&
                        inode->i_ino == F2FS_ROOT_INO(sbi))
                return -EPERM;
 
        __u32 crc = 0;
 
        /* Check checksum_offset and crc in superblock */
-       if (le32_to_cpu(raw_super->feature) & F2FS_FEATURE_SB_CHKSUM) {
+       if (__F2FS_HAS_FEATURE(raw_super, F2FS_FEATURE_SB_CHKSUM)) {
                crc_offset = le32_to_cpu(raw_super->checksum_offset);
                if (crc_offset !=
                        offsetof(struct f2fs_super_block, crc)) {
        unsigned int n = 0;
        int err = -EIO;
 
-       if (!f2fs_sb_has_blkzoned(sbi->sb))
+       if (!f2fs_sb_has_blkzoned(sbi))
                return 0;
 
        if (sbi->blocks_per_blkz && sbi->blocks_per_blkz !=
        }
 
        /* we should update superblock crc here */
-       if (!recover && f2fs_sb_has_sb_chksum(sbi->sb)) {
+       if (!recover && f2fs_sb_has_sb_chksum(sbi)) {
                crc = f2fs_crc32(sbi, F2FS_RAW_SUPER(sbi),
                                offsetof(struct f2fs_super_block, crc));
                F2FS_RAW_SUPER(sbi)->crc = cpu_to_le32(crc);
 
 #ifdef CONFIG_BLK_DEV_ZONED
                if (bdev_zoned_model(FDEV(i).bdev) == BLK_ZONED_HM &&
-                               !f2fs_sb_has_blkzoned(sbi->sb)) {
+                               !f2fs_sb_has_blkzoned(sbi)) {
                        f2fs_msg(sbi->sb, KERN_ERR,
                                "Zoned block device feature not enabled\n");
                        return -EINVAL;
        sbi->raw_super = raw_super;
 
        /* precompute checksum seed for metadata */
-       if (f2fs_sb_has_inode_chksum(sb))
+       if (f2fs_sb_has_inode_chksum(sbi))
                sbi->s_chksum_seed = f2fs_chksum(sbi, ~0, raw_super->uuid,
                                                sizeof(raw_super->uuid));
 
         * devices, but mandatory for host-managed zoned block devices.
         */
 #ifndef CONFIG_BLK_DEV_ZONED
-       if (f2fs_sb_has_blkzoned(sb)) {
+       if (f2fs_sb_has_blkzoned(sbi)) {
                f2fs_msg(sb, KERN_ERR,
                         "Zoned block device support is not enabled\n");
                err = -EOPNOTSUPP;
 
 #ifdef CONFIG_QUOTA
        sb->dq_op = &f2fs_quota_operations;
-       if (f2fs_sb_has_quota_ino(sb))
+       if (f2fs_sb_has_quota_ino(sbi))
                sb->s_qcop = &dquot_quotactl_sysfile_ops;
        else
                sb->s_qcop = &f2fs_quotactl_ops;
        sb->s_quota_types = QTYPE_MASK_USR | QTYPE_MASK_GRP | QTYPE_MASK_PRJ;
 
-       if (f2fs_sb_has_quota_ino(sbi->sb)) {
+       if (f2fs_sb_has_quota_ino(sbi)) {
                for (i = 0; i < MAXQUOTAS; i++) {
                        if (f2fs_qf_ino(sbi->sb, i))
                                sbi->nquota_files++;
 
 #ifdef CONFIG_QUOTA
        /* Enable quota usage during mount */
-       if (f2fs_sb_has_quota_ino(sb) && !f2fs_readonly(sb)) {
+       if (f2fs_sb_has_quota_ino(sbi) && !f2fs_readonly(sb)) {
                err = f2fs_enable_quotas(sb);
                if (err)
                        f2fs_msg(sb, KERN_ERR,
 free_meta:
 #ifdef CONFIG_QUOTA
        f2fs_truncate_quota_inode_pages(sb);
-       if (f2fs_sb_has_quota_ino(sb) && !f2fs_readonly(sb))
+       if (f2fs_sb_has_quota_ino(sbi) && !f2fs_readonly(sb))
                f2fs_quota_off_umount(sbi->sb);
 #endif
        /*
 
        if (!sb->s_bdev->bd_part)
                return snprintf(buf, PAGE_SIZE, "0\n");
 
-       if (f2fs_sb_has_encrypt(sb))
+       if (f2fs_sb_has_encrypt(sbi))
                len += snprintf(buf, PAGE_SIZE - len, "%s",
                                                "encryption");
-       if (f2fs_sb_has_blkzoned(sb))
+       if (f2fs_sb_has_blkzoned(sbi))
                len += snprintf(buf + len, PAGE_SIZE - len, "%s%s",
                                len ? ", " : "", "blkzoned");
-       if (f2fs_sb_has_extra_attr(sb))
+       if (f2fs_sb_has_extra_attr(sbi))
                len += snprintf(buf + len, PAGE_SIZE - len, "%s%s",
                                len ? ", " : "", "extra_attr");
-       if (f2fs_sb_has_project_quota(sb))
+       if (f2fs_sb_has_project_quota(sbi))
                len += snprintf(buf + len, PAGE_SIZE - len, "%s%s",
                                len ? ", " : "", "projquota");
-       if (f2fs_sb_has_inode_chksum(sb))
+       if (f2fs_sb_has_inode_chksum(sbi))
                len += snprintf(buf + len, PAGE_SIZE - len, "%s%s",
                                len ? ", " : "", "inode_checksum");
-       if (f2fs_sb_has_flexible_inline_xattr(sb))
+       if (f2fs_sb_has_flexible_inline_xattr(sbi))
                len += snprintf(buf + len, PAGE_SIZE - len, "%s%s",
                                len ? ", " : "", "flexible_inline_xattr");
-       if (f2fs_sb_has_quota_ino(sb))
+       if (f2fs_sb_has_quota_ino(sbi))
                len += snprintf(buf + len, PAGE_SIZE - len, "%s%s",
                                len ? ", " : "", "quota_ino");
-       if (f2fs_sb_has_inode_crtime(sb))
+       if (f2fs_sb_has_inode_crtime(sbi))
                len += snprintf(buf + len, PAGE_SIZE - len, "%s%s",
                                len ? ", " : "", "inode_crtime");
-       if (f2fs_sb_has_lost_found(sb))
+       if (f2fs_sb_has_lost_found(sbi))
                len += snprintf(buf + len, PAGE_SIZE - len, "%s%s",
                                len ? ", " : "", "lost_found");
-       if (f2fs_sb_has_sb_chksum(sb))
+       if (f2fs_sb_has_sb_chksum(sbi))
                len += snprintf(buf + len, PAGE_SIZE - len, "%s%s",
                                len ? ", " : "", "sb_checksum");
        len += snprintf(buf + len, PAGE_SIZE - len, "\n");