aboutsummaryrefslogtreecommitdiffstats
path: root/fs/ext4/mballoc.c
diff options
context:
space:
mode:
authorTheodore Ts'o <tytso@mit.edu>2011-01-10 12:12:36 -0500
committerTheodore Ts'o <tytso@mit.edu>2011-01-10 12:12:36 -0500
commitf232109773ff5b0c840a6761d74940b9cf0d66ec (patch)
treea32da5ebd1a3e074e9f52107f3bdc23babb6340c /fs/ext4/mballoc.c
parentad4fb9cafe100a4a9de6e0529015e584d94ac8dc (diff)
ext4: replace i_delalloc_reserved_flag with EXT4_STATE_DELALLOC_RESERVED
Remove the short element i_delalloc_reserved_flag from the ext4_inode_info structure and replace it a new bit in i_state_flags. Since we have an ext4_inode_info for every ext4 inode cached in the inode cache, any savings we can produce here is a very good thing from a memory utilization perspective. Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
Diffstat (limited to 'fs/ext4/mballoc.c')
-rw-r--r--fs/ext4/mballoc.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/fs/ext4/mballoc.c b/fs/ext4/mballoc.c
index 12b604abc2fe..d47a80ec231d 100644
--- a/fs/ext4/mballoc.c
+++ b/fs/ext4/mballoc.c
@@ -4283,7 +4283,7 @@ ext4_fsblk_t ext4_mb_new_blocks(handle_t *handle,
4283 * EDQUOT check, as blocks and quotas have been already 4283 * EDQUOT check, as blocks and quotas have been already
4284 * reserved when data being copied into pagecache. 4284 * reserved when data being copied into pagecache.
4285 */ 4285 */
4286 if (EXT4_I(ar->inode)->i_delalloc_reserved_flag) 4286 if (ext4_test_inode_state(ar->inode, EXT4_STATE_DELALLOC_RESERVED))
4287 ar->flags |= EXT4_MB_DELALLOC_RESERVED; 4287 ar->flags |= EXT4_MB_DELALLOC_RESERVED;
4288 else { 4288 else {
4289 /* Without delayed allocation we need to verify 4289 /* Without delayed allocation we need to verify
@@ -4380,7 +4380,8 @@ out:
4380 if (inquota && ar->len < inquota) 4380 if (inquota && ar->len < inquota)
4381 dquot_free_block(ar->inode, inquota - ar->len); 4381 dquot_free_block(ar->inode, inquota - ar->len);
4382 if (!ar->len) { 4382 if (!ar->len) {
4383 if (!EXT4_I(ar->inode)->i_delalloc_reserved_flag) 4383 if (!ext4_test_inode_state(ar->inode,
4384 EXT4_STATE_DELALLOC_RESERVED))
4384 /* release all the reserved blocks if non delalloc */ 4385 /* release all the reserved blocks if non delalloc */
4385 percpu_counter_sub(&sbi->s_dirtyblocks_counter, 4386 percpu_counter_sub(&sbi->s_dirtyblocks_counter,
4386 reserv_blks); 4387 reserv_blks);