summaryrefslogtreecommitdiffstats
path: root/fs/f2fs/node.c
diff options
context:
space:
mode:
authorJaegeuk Kim <jaegeuk@kernel.org>2016-06-03 00:24:24 +0200
committerJaegeuk Kim <jaegeuk@kernel.org>2016-06-07 19:18:08 +0200
commite589c2c477b44e06754508a4e8b883e5ae7294aa (patch)
treeccdca1631cd37f7eef8286e0d12ddbe1e677cec8 /fs/f2fs/node.c
parentf2fs: fix wrong percentage (diff)
downloadlinux-e589c2c477b44e06754508a4e8b883e5ae7294aa.tar.xz
linux-e589c2c477b44e06754508a4e8b883e5ae7294aa.zip
f2fs: control not to exceed # of cached nat entries
This is to avoid cache entry management overhead including radix tree. Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
Diffstat (limited to 'fs/f2fs/node.c')
-rw-r--r--fs/f2fs/node.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/fs/f2fs/node.c b/fs/f2fs/node.c
index 16532b31dcd6..b448c8fec7fc 100644
--- a/fs/f2fs/node.c
+++ b/fs/f2fs/node.c
@@ -52,6 +52,10 @@ bool available_free_memory(struct f2fs_sb_info *sbi, int type)
mem_size = (nm_i->nat_cnt * sizeof(struct nat_entry)) >>
PAGE_SHIFT;
res = mem_size < ((avail_ram * nm_i->ram_thresh / 100) >> 2);
+ if (excess_cached_nats(sbi))
+ res = false;
+ if (nm_i->nat_cnt > DEF_NAT_CACHE_THRESHOLD)
+ res = false;
} else if (type == DIRTY_DENTS) {
if (sbi->sb->s_bdi->wb.dirty_exceeded)
return false;