Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Unverified Commit 00873ba0 authored by Gao Xiang's avatar Gao Xiang Committed by Michael Bestas
Browse files

UPSTREAM: erofs: introduce erofs_sb_has_xxx() helpers

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: default avatarChao Yu <yuchao0@huawei.com>
Signed-off-by: default avatarGao Xiang <hsiangkao@redhat.com>

Bug: 201372112
Change-Id: I145fa9c670284b609b59a246f918fb09dc562356
(cherry picked from commit de06a6a375414be03ce5b1054f2d836591923a1d)
Signed-off-by: default avatarHuang Jianan <huangjianan@oppo.com>
parent 33efea02
Loading
Loading
Loading
Loading
+1 −2
Original line number Original line Diff line number Diff line
@@ -141,8 +141,7 @@ static int z_erofs_lz4_decompress(struct z_erofs_decompress_req *rq, u8 *out)
	support_0padding = false;
	support_0padding = false;


	/* decompression inplace is only safe when 0padding is enabled */
	/* decompression inplace is only safe when 0padding is enabled */
	if (EROFS_SB(rq->sb)->feature_incompat &
	if (erofs_sb_has_lz4_0padding(EROFS_SB(rq->sb))) {
	    EROFS_FEATURE_INCOMPAT_LZ4_0PADDING) {
		support_0padding = true;
		support_0padding = true;


		while (!src[inputmargin & ~PAGE_MASK])
		while (!src[inputmargin & ~PAGE_MASK])
+9 −0
Original line number Original line Diff line number Diff line
@@ -226,6 +226,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);
	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 */
/* atomic flag definitions */
#define EROFS_I_EA_INITED_BIT	0
#define EROFS_I_EA_INITED_BIT	0
#define EROFS_I_Z_INITED_BIT	1
#define EROFS_I_Z_INITED_BIT	1
+1 −1
Original line number Original line Diff line number Diff line
@@ -149,7 +149,7 @@ static int erofs_read_superblock(struct super_block *sb)
	}
	}


	sbi->feature_compat = le32_to_cpu(dsb->feature_compat);
	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);
		ret = erofs_superblock_csum_verify(sb, data);
		if (ret)
		if (ret)
			goto out;
			goto out;