]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
erofs: introduce erofs_sb_has_xxx() helpers
authorGao Xiang <hsiangkao@redhat.com>
Mon, 29 Mar 2021 01:23:05 +0000 (09:23 +0800)
committerGao Xiang <hsiangkao@redhat.com>
Mon, 29 Mar 2021 02:24:57 +0000 (10:24 +0800)
Introduce erofs_sb_has_xxx() to make long checks short, especially
for later big pcluster & LZMA features.

Link: https://lore.kernel.org/r/20210329012308.28743-2-hsiangkao@aol.com
Reviewed-by: Chao Yu <yuchao0@huawei.com>
Signed-off-by: Gao Xiang <hsiangkao@redhat.com>
fs/erofs/decompressor.c
fs/erofs/internal.h
fs/erofs/super.c

index 34e73ff76f89eb8a53eba82643da625242246c18..80e8871aef71cdd601322d3bad3fb04a1bc1a384 100644 (file)
@@ -124,8 +124,7 @@ static int z_erofs_lz4_decompress(struct z_erofs_decompress_req *rq, u8 *out)
        support_0padding = false;
 
        /* decompression inplace is only safe when 0padding is enabled */
-       if (EROFS_SB(rq->sb)->feature_incompat &
-           EROFS_FEATURE_INCOMPAT_LZ4_0PADDING) {
+       if (erofs_sb_has_lz4_0padding(EROFS_SB(rq->sb))) {
                support_0padding = true;
 
                while (!src[inputmargin & ~PAGE_MASK])
index db8c8470269e5356dd23137b3ec94371a1929a3d..a148a039cf675e74b9300b0bf4784220f6809b12 100644 (file)
@@ -218,6 +218,15 @@ static inline erofs_off_t iloc(struct erofs_sb_info *sbi, erofs_nid_t nid)
        return blknr_to_addr(sbi->meta_blkaddr) + (nid << sbi->islotbits);
 }
 
+#define EROFS_FEATURE_FUNCS(name, compat, feature) \
+static inline bool erofs_sb_has_##name(struct erofs_sb_info *sbi) \
+{ \
+       return sbi->feature_##compat & EROFS_FEATURE_##feature; \
+}
+
+EROFS_FEATURE_FUNCS(lz4_0padding, incompat, INCOMPAT_LZ4_0PADDING)
+EROFS_FEATURE_FUNCS(sb_chksum, compat, COMPAT_SB_CHKSUM)
+
 /* atomic flag definitions */
 #define EROFS_I_EA_INITED_BIT  0
 #define EROFS_I_Z_INITED_BIT   1
index 0445d09b633103de511dd0c3fd1ead1cb5364be4..991b99eaf22a8fc6e216941f4ba2d4a4a2b2ca71 100644 (file)
@@ -149,7 +149,7 @@ static int erofs_read_superblock(struct super_block *sb)
        }
 
        sbi->feature_compat = le32_to_cpu(dsb->feature_compat);
-       if (sbi->feature_compat & EROFS_FEATURE_COMPAT_SB_CHKSUM) {
+       if (erofs_sb_has_sb_chksum(sbi)) {
                ret = erofs_superblock_csum_verify(sb, data);
                if (ret)
                        goto out;