f2fs: do not skip dentry block writes
Previously, we skip dentry block writes when wbc is SYNC_NONE with no memory pressure and the number of dirty pages is pretty small. But, we didn't skip for normal data writes, which gives us not much big impact on overall performance. Moreover, by skipping some data writes, kworker falls into infinite loop to try to write blocks, when many dir inodes have only one dentry block. So, this patch removes skipping data writes. Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
This commit is contained in:
parent
7223554133
commit
90b803e6fb
@ -1340,11 +1340,6 @@ static int f2fs_write_data_pages(struct address_space *mapping,
|
|||||||
if (!get_dirty_pages(inode) && wbc->sync_mode == WB_SYNC_NONE)
|
if (!get_dirty_pages(inode) && wbc->sync_mode == WB_SYNC_NONE)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (S_ISDIR(inode->i_mode) && wbc->sync_mode == WB_SYNC_NONE &&
|
|
||||||
get_dirty_pages(inode) < nr_pages_to_skip(sbi, DATA) &&
|
|
||||||
available_free_memory(sbi, DIRTY_DENTS))
|
|
||||||
goto skip_write;
|
|
||||||
|
|
||||||
/* during POR, we don't need to trigger writepage at all. */
|
/* during POR, we don't need to trigger writepage at all. */
|
||||||
if (unlikely(is_sbi_flag_set(sbi, SBI_POR_DOING)))
|
if (unlikely(is_sbi_flag_set(sbi, SBI_POR_DOING)))
|
||||||
goto skip_write;
|
goto skip_write;
|
||||||
|
@ -52,11 +52,6 @@ bool available_free_memory(struct f2fs_sb_info *sbi, int type)
|
|||||||
mem_size = (nm_i->nat_cnt * sizeof(struct nat_entry)) >>
|
mem_size = (nm_i->nat_cnt * sizeof(struct nat_entry)) >>
|
||||||
PAGE_CACHE_SHIFT;
|
PAGE_CACHE_SHIFT;
|
||||||
res = mem_size < ((avail_ram * nm_i->ram_thresh / 100) >> 2);
|
res = mem_size < ((avail_ram * nm_i->ram_thresh / 100) >> 2);
|
||||||
} else if (type == DIRTY_DENTS) {
|
|
||||||
if (sbi->sb->s_bdi->wb.dirty_exceeded)
|
|
||||||
return false;
|
|
||||||
mem_size = get_pages(sbi, F2FS_DIRTY_DENTS);
|
|
||||||
res = mem_size < ((avail_ram * nm_i->ram_thresh / 100) >> 1);
|
|
||||||
} else if (type == INO_ENTRIES) {
|
} else if (type == INO_ENTRIES) {
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
@ -118,7 +118,6 @@ static inline void raw_nat_from_node_info(struct f2fs_nat_entry *raw_ne,
|
|||||||
enum mem_type {
|
enum mem_type {
|
||||||
FREE_NIDS, /* indicates the free nid list */
|
FREE_NIDS, /* indicates the free nid list */
|
||||||
NAT_ENTRIES, /* indicates the cached nat entry */
|
NAT_ENTRIES, /* indicates the cached nat entry */
|
||||||
DIRTY_DENTS, /* indicates dirty dentry pages */
|
|
||||||
INO_ENTRIES, /* indicates inode entries */
|
INO_ENTRIES, /* indicates inode entries */
|
||||||
EXTENT_CACHE, /* indicates extent cache */
|
EXTENT_CACHE, /* indicates extent cache */
|
||||||
BASE_CHECK, /* check kernel status */
|
BASE_CHECK, /* check kernel status */
|
||||||
|
@ -697,9 +697,7 @@ static inline int nr_pages_to_skip(struct f2fs_sb_info *sbi, int type)
|
|||||||
if (sbi->sb->s_bdi->wb.dirty_exceeded)
|
if (sbi->sb->s_bdi->wb.dirty_exceeded)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (type == DATA)
|
if (type == NODE)
|
||||||
return sbi->blocks_per_seg;
|
|
||||||
else if (type == NODE)
|
|
||||||
return 3 * sbi->blocks_per_seg;
|
return 3 * sbi->blocks_per_seg;
|
||||||
else if (type == META)
|
else if (type == META)
|
||||||
return MAX_BIO_BLOCKS(sbi);
|
return MAX_BIO_BLOCKS(sbi);
|
||||||
|
Loading…
Reference in New Issue
Block a user