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

Commit 5d2b42ed authored by Shuoran Liu's avatar Shuoran Liu Committed by Jaegeuk Kim
Browse files

f2fs: fix a bug when using namehash to locate dentry bucket



In the following scenario,

1) we don't have the key and doing a lookup for encrypted file,
2) and the encrypted filename is big name

we should use fname->hash as name hash value instead of what is
calculated by fname->disk_name. Because in such case,
fname->disk_name is empty.

Signed-off-by: default avatarShuoran Liu <liushuoran@huawei.com>
Acked-by: default avatarChao Yu <yuchao0@huawei.com>
Signed-off-by: default avatarJaegeuk Kim <jaegeuk@kernel.org>
parent dfd02e4d
Loading
Loading
Loading
Loading
+4 −1
Original line number Diff line number Diff line
@@ -172,6 +172,9 @@ static struct f2fs_dir_entry *find_in_level(struct inode *dir,
	int max_slots;
	f2fs_hash_t namehash;

	if(fname->hash)
		namehash = cpu_to_le32(fname->hash);
	else
		namehash = f2fs_dentry_hash(&name);

	nbucket = dir_buckets(level, F2FS_I(dir)->i_dir_level);