diff options
Diffstat (limited to 'fs/ext4/inode.c')
-rw-r--r-- | fs/ext4/inode.c | 18 |
1 files changed, 10 insertions, 8 deletions
diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c index 904a9a623dab..40f51aae42fe 100644 --- a/fs/ext4/inode.c +++ b/fs/ext4/inode.c | |||
@@ -281,7 +281,7 @@ void ext4_da_update_reserve_space(struct inode *inode, | |||
281 | /* Update per-inode reservations */ | 281 | /* Update per-inode reservations */ |
282 | ei->i_reserved_data_blocks -= used; | 282 | ei->i_reserved_data_blocks -= used; |
283 | ei->i_reserved_meta_blocks -= ei->i_allocated_meta_blocks; | 283 | ei->i_reserved_meta_blocks -= ei->i_allocated_meta_blocks; |
284 | percpu_counter_sub(&sbi->s_dirtyblocks_counter, | 284 | percpu_counter_sub(&sbi->s_dirtyclusters_counter, |
285 | used + ei->i_allocated_meta_blocks); | 285 | used + ei->i_allocated_meta_blocks); |
286 | ei->i_allocated_meta_blocks = 0; | 286 | ei->i_allocated_meta_blocks = 0; |
287 | 287 | ||
@@ -291,7 +291,7 @@ void ext4_da_update_reserve_space(struct inode *inode, | |||
291 | * only when we have written all of the delayed | 291 | * only when we have written all of the delayed |
292 | * allocation blocks. | 292 | * allocation blocks. |
293 | */ | 293 | */ |
294 | percpu_counter_sub(&sbi->s_dirtyblocks_counter, | 294 | percpu_counter_sub(&sbi->s_dirtyclusters_counter, |
295 | ei->i_reserved_meta_blocks); | 295 | ei->i_reserved_meta_blocks); |
296 | ei->i_reserved_meta_blocks = 0; | 296 | ei->i_reserved_meta_blocks = 0; |
297 | ei->i_da_metadata_calc_len = 0; | 297 | ei->i_da_metadata_calc_len = 0; |
@@ -1119,14 +1119,14 @@ static void ext4_da_release_space(struct inode *inode, int to_free) | |||
1119 | * only when we have written all of the delayed | 1119 | * only when we have written all of the delayed |
1120 | * allocation blocks. | 1120 | * allocation blocks. |
1121 | */ | 1121 | */ |
1122 | percpu_counter_sub(&sbi->s_dirtyblocks_counter, | 1122 | percpu_counter_sub(&sbi->s_dirtyclusters_counter, |
1123 | ei->i_reserved_meta_blocks); | 1123 | ei->i_reserved_meta_blocks); |
1124 | ei->i_reserved_meta_blocks = 0; | 1124 | ei->i_reserved_meta_blocks = 0; |
1125 | ei->i_da_metadata_calc_len = 0; | 1125 | ei->i_da_metadata_calc_len = 0; |
1126 | } | 1126 | } |
1127 | 1127 | ||
1128 | /* update fs dirty data blocks counter */ | 1128 | /* update fs dirty data blocks counter */ |
1129 | percpu_counter_sub(&sbi->s_dirtyblocks_counter, to_free); | 1129 | percpu_counter_sub(&sbi->s_dirtyclusters_counter, to_free); |
1130 | 1130 | ||
1131 | spin_unlock(&EXT4_I(inode)->i_block_reservation_lock); | 1131 | spin_unlock(&EXT4_I(inode)->i_block_reservation_lock); |
1132 | 1132 | ||
@@ -1349,9 +1349,10 @@ static void ext4_print_free_blocks(struct inode *inode) | |||
1349 | ext4_count_free_blocks(inode->i_sb)); | 1349 | ext4_count_free_blocks(inode->i_sb)); |
1350 | printk(KERN_CRIT "Free/Dirty block details\n"); | 1350 | printk(KERN_CRIT "Free/Dirty block details\n"); |
1351 | printk(KERN_CRIT "free_blocks=%lld\n", | 1351 | printk(KERN_CRIT "free_blocks=%lld\n", |
1352 | (long long) percpu_counter_sum(&sbi->s_freeblocks_counter)); | 1352 | (long long) EXT4_C2B(EXT4_SB(inode->i_sb), |
1353 | percpu_counter_sum(&sbi->s_freeclusters_counter))); | ||
1353 | printk(KERN_CRIT "dirty_blocks=%lld\n", | 1354 | printk(KERN_CRIT "dirty_blocks=%lld\n", |
1354 | (long long) percpu_counter_sum(&sbi->s_dirtyblocks_counter)); | 1355 | (long long) percpu_counter_sum(&sbi->s_dirtyclusters_counter)); |
1355 | printk(KERN_CRIT "Block reservation details\n"); | 1356 | printk(KERN_CRIT "Block reservation details\n"); |
1356 | printk(KERN_CRIT "i_reserved_data_blocks=%u\n", | 1357 | printk(KERN_CRIT "i_reserved_data_blocks=%u\n", |
1357 | EXT4_I(inode)->i_reserved_data_blocks); | 1358 | EXT4_I(inode)->i_reserved_data_blocks); |
@@ -2226,8 +2227,9 @@ static int ext4_nonda_switch(struct super_block *sb) | |||
2226 | * Delalloc need an accurate free block accounting. So switch | 2227 | * Delalloc need an accurate free block accounting. So switch |
2227 | * to non delalloc when we are near to error range. | 2228 | * to non delalloc when we are near to error range. |
2228 | */ | 2229 | */ |
2229 | free_blocks = percpu_counter_read_positive(&sbi->s_freeblocks_counter); | 2230 | free_blocks = EXT4_C2B(sbi, |
2230 | dirty_blocks = percpu_counter_read_positive(&sbi->s_dirtyblocks_counter); | 2231 | percpu_counter_read_positive(&sbi->s_freeclusters_counter)); |
2232 | dirty_blocks = percpu_counter_read_positive(&sbi->s_dirtyclusters_counter); | ||
2231 | if (2 * free_blocks < 3 * dirty_blocks || | 2233 | if (2 * free_blocks < 3 * dirty_blocks || |
2232 | free_blocks < (dirty_blocks + EXT4_FREEBLOCKS_WATERMARK)) { | 2234 | free_blocks < (dirty_blocks + EXT4_FREEBLOCKS_WATERMARK)) { |
2233 | /* | 2235 | /* |