mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-09 20:32:04 +09:00
ext4: Fixed inode allocator to correctly track a flex_bg's used_dirs
commit c4caae2518 upstream (as of v2.6.34-rc3)
When used_dirs was introduced for the flex_groups struct, it looks
like the accounting was not put into place properly, in some places
manipulating free_inodes rather than used_dirs.
Signed-off-by: Eric Sandeen <sandeen@redhat.com>
Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
112ba39e2f
commit
84b29e4a50
@@ -268,7 +268,7 @@ void ext4_free_inode(handle_t *handle, struct inode *inode)
|
||||
ext4_group_t f;
|
||||
|
||||
f = ext4_flex_group(sbi, block_group);
|
||||
atomic_dec(&sbi->s_flex_groups[f].free_inodes);
|
||||
atomic_dec(&sbi->s_flex_groups[f].used_dirs);
|
||||
}
|
||||
|
||||
}
|
||||
@@ -779,7 +779,7 @@ static int ext4_claim_inode(struct super_block *sb,
|
||||
if (sbi->s_log_groups_per_flex) {
|
||||
ext4_group_t f = ext4_flex_group(sbi, group);
|
||||
|
||||
atomic_inc(&sbi->s_flex_groups[f].free_inodes);
|
||||
atomic_inc(&sbi->s_flex_groups[f].used_dirs);
|
||||
}
|
||||
}
|
||||
gdp->bg_checksum = ext4_group_desc_csum(sbi, group, gdp);
|
||||
|
||||
Reference in New Issue
Block a user