mirror of https://gitee.com/openkylin/linux.git
Description for this pull request:
- Improved compatibility issue with exfat from some camera vendors. - Do not need to release root inode on error path. -----BEGIN PGP SIGNATURE----- iQJMBAABCgA2FiEE6NzKS6Uv/XAAGHgyZwv7A1FEIQgFAmDhB1QYHG5hbWphZS5q ZW9uQHNhbXN1bmcuY29tAAoJEGcL+wNRRCEIf/sQAMtOahaIoZzdF/5Iprk4dP5b y8l0C1dM+Ijkc/F0VvfXfdAbRzbXYfd7hh5JyJGXQYdvo6NxjEQ9xSEWPbYxEBJg zUc2jKG1Qgmcy7XKAqcFDZjogBFtAqYsDseN0RDiRpUFwrFkT2wE4pC3TLVTK2+b GKDxoQdzoXp/BfyHJ03YXxxzwDyBmYK7/7yulLA1nVOiNrRcN7foImylZ+6j24u0 3IwxqWfbubl5kH9ABn77ZWI1yhwTRHczhIBh4GBDO/6/+HOsvFOoednQ3i/7lx9q d2JZqRYyV0Nrxnfy1LAkJ4G4UiZURaLM7UEQUDMFxwqYPAmfW2FiAFx8OvoPoTz6 ZxYOUSFg/GZOuYSXa5/NF/Gf2qO1sBdFvqnqXn81sJK0L/5BW98YYayCMkdWtvCn KFWTi7FCtcotJwsirrYom4rsXx5YfSDCCiLhhwo4j43MepA8krDdLcuBxRRp6LRC QZEd7k/gdHvcqxFYYeYM4U5c6m3ASvoT6vJ9kA+P39NwWjrE2wVH1QP3HPVTm1w7 7P4K/mTrE62VcWEzimtbTtNLfmknPA9eEuzxg7mC9QJdN0VczJ24BXxKRqJg95fd yjVNwbsxkwUHXt6GITVGFJkE3E7GIVS9/Ket6VjMZAcSACJjznnL1nnlklu1b6MS k40sJJ1o0VLB5JmKQxY/ =U4e0 -----END PGP SIGNATURE----- Merge tag 'exfat-for-5.14-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/linkinjeon/exfat Pull exfat updates from Namjae Jeon: - Improved compatibility issue with exfat from some camera vendors. - Do not need to release root inode on error path. * tag 'exfat-for-5.14-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/linkinjeon/exfat: exfat: handle wrong stream entry size in exfat_readdir() exfat: avoid incorrectly releasing for root inode
This commit is contained in:
commit
7a5e9a17b2
|
@ -63,7 +63,7 @@ static void exfat_get_uniname_from_ext_entry(struct super_block *sb,
|
||||||
static int exfat_readdir(struct inode *inode, loff_t *cpos, struct exfat_dir_entry *dir_entry)
|
static int exfat_readdir(struct inode *inode, loff_t *cpos, struct exfat_dir_entry *dir_entry)
|
||||||
{
|
{
|
||||||
int i, dentries_per_clu, dentries_per_clu_bits = 0, num_ext;
|
int i, dentries_per_clu, dentries_per_clu_bits = 0, num_ext;
|
||||||
unsigned int type, clu_offset;
|
unsigned int type, clu_offset, max_dentries;
|
||||||
sector_t sector;
|
sector_t sector;
|
||||||
struct exfat_chain dir, clu;
|
struct exfat_chain dir, clu;
|
||||||
struct exfat_uni_name uni_name;
|
struct exfat_uni_name uni_name;
|
||||||
|
@ -86,6 +86,8 @@ static int exfat_readdir(struct inode *inode, loff_t *cpos, struct exfat_dir_ent
|
||||||
|
|
||||||
dentries_per_clu = sbi->dentries_per_clu;
|
dentries_per_clu = sbi->dentries_per_clu;
|
||||||
dentries_per_clu_bits = ilog2(dentries_per_clu);
|
dentries_per_clu_bits = ilog2(dentries_per_clu);
|
||||||
|
max_dentries = (unsigned int)min_t(u64, MAX_EXFAT_DENTRIES,
|
||||||
|
(u64)sbi->num_clusters << dentries_per_clu_bits);
|
||||||
|
|
||||||
clu_offset = dentry >> dentries_per_clu_bits;
|
clu_offset = dentry >> dentries_per_clu_bits;
|
||||||
exfat_chain_dup(&clu, &dir);
|
exfat_chain_dup(&clu, &dir);
|
||||||
|
@ -109,7 +111,7 @@ static int exfat_readdir(struct inode *inode, loff_t *cpos, struct exfat_dir_ent
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
while (clu.dir != EXFAT_EOF_CLUSTER) {
|
while (clu.dir != EXFAT_EOF_CLUSTER && dentry < max_dentries) {
|
||||||
i = dentry & (dentries_per_clu - 1);
|
i = dentry & (dentries_per_clu - 1);
|
||||||
|
|
||||||
for ( ; i < dentries_per_clu; i++, dentry++) {
|
for ( ; i < dentries_per_clu; i++, dentry++) {
|
||||||
|
@ -245,7 +247,7 @@ static int exfat_iterate(struct file *filp, struct dir_context *ctx)
|
||||||
if (err)
|
if (err)
|
||||||
goto unlock;
|
goto unlock;
|
||||||
get_new:
|
get_new:
|
||||||
if (cpos >= i_size_read(inode))
|
if (ei->flags == ALLOC_NO_FAT_CHAIN && cpos >= i_size_read(inode))
|
||||||
goto end_of_dir;
|
goto end_of_dir;
|
||||||
|
|
||||||
err = exfat_readdir(inode, &cpos, &de);
|
err = exfat_readdir(inode, &cpos, &de);
|
||||||
|
|
|
@ -690,7 +690,7 @@ static int exfat_fill_super(struct super_block *sb, struct fs_context *fc)
|
||||||
if (!sb->s_root) {
|
if (!sb->s_root) {
|
||||||
exfat_err(sb, "failed to get the root dentry");
|
exfat_err(sb, "failed to get the root dentry");
|
||||||
err = -ENOMEM;
|
err = -ENOMEM;
|
||||||
goto put_inode;
|
goto free_table;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
Loading…
Reference in New Issue