aboutsummaryrefslogtreecommitdiffstats
path: root/fs/f2fs
diff options
context:
space:
mode:
authorNamjae Jeon <namjae.jeon@samsung.com>2013-06-08 08:25:40 -0400
committerJaegeuk Kim <jaegeuk.kim@samsung.com>2013-06-13 20:04:42 -0400
commitd7cc950b4c910e4440485be784493880a0d09086 (patch)
treead61daad74fa7f6fd0153cf9597bfc8b2e0710b4 /fs/f2fs
parent6a3e8ef0de1e548d1cf9bcf51d9b7b6f4141fec5 (diff)
f2fs: optimise the truncate_data_blocks_range() range
The function truncate_data_blocks_range() decrements the valid block count of inode via dec_valid_block_count(). Since this function updates the i_blocks field of inode, we can update this field once we have calculated total the number of blocks to be freed. Therefore we can decrement valid blocks outside of the for loop. if (nr_free) { + dec_valid_block_count(sbi, dn->inode, nr_free); set_page_dirty(dn->node_page); sync_inode_page(dn); } 'nr_free' tells the total number of blocks freed. So, we can just directly pass this value to dec_valid_block_count() and update the i_blocks. Signed-off-by: Namjae Jeon <namjae.jeon@samsung.com> Signed-off-by: Pankaj Kumar <pankaj.km@samsung.com> Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
Diffstat (limited to 'fs/f2fs')
-rw-r--r--fs/f2fs/file.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/f2fs/file.c b/fs/f2fs/file.c
index 85b665d176a2..2f649b848521 100644
--- a/fs/f2fs/file.c
+++ b/fs/f2fs/file.c
@@ -185,10 +185,10 @@ int truncate_data_blocks_range(struct dnode_of_data *dn, int count)
185 185
186 update_extent_cache(NULL_ADDR, dn); 186 update_extent_cache(NULL_ADDR, dn);
187 invalidate_blocks(sbi, blkaddr); 187 invalidate_blocks(sbi, blkaddr);
188 dec_valid_block_count(sbi, dn->inode, 1);
189 nr_free++; 188 nr_free++;
190 } 189 }
191 if (nr_free) { 190 if (nr_free) {
191 dec_valid_block_count(sbi, dn->inode, nr_free);
192 set_page_dirty(dn->node_page); 192 set_page_dirty(dn->node_page);
193 sync_inode_page(dn); 193 sync_inode_page(dn);
194 } 194 }