aboutsummaryrefslogtreecommitdiffstats
path: root/fs/f2fs/recovery.c
diff options
context:
space:
mode:
authorJaegeuk Kim <jaegeuk.kim@samsung.com>2014-04-14 22:19:28 -0400
committerJaegeuk Kim <jaegeuk.kim@samsung.com>2014-05-06 21:21:54 -0400
commited57c27f736f6d8a51e442610c800ee0c3d83977 (patch)
treef1d453fae0ba5b9d5ca938fb0d57aedd762a5c58 /fs/f2fs/recovery.c
parent15c6e3aae68d6167cba063387a59968f811c8268 (diff)
f2fs: remove costly dirty_dir_inode operations
This patch removes list opeations in handling dirty dir inodes. Previously, F2FS traverses whole the list of dirty dir inodes to check whether there is an existing inode or not, resulting in heavy CPU overheads. So this patch removes such the traverse operations by adding FI_DIRTY_DIR to indicate the inode lies on the list or not. Through this simple flag, we can remove redundant operations gracefully. Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
Diffstat (limited to 'fs/f2fs/recovery.c')
-rw-r--r--fs/f2fs/recovery.c18
1 files changed, 10 insertions, 8 deletions
diff --git a/fs/f2fs/recovery.c b/fs/f2fs/recovery.c
index b1ae89f0f44e..9eb6487f383d 100644
--- a/fs/f2fs/recovery.c
+++ b/fs/f2fs/recovery.c
@@ -46,15 +46,17 @@ static int recover_dentry(struct page *ipage, struct inode *inode)
46 struct inode *dir, *einode; 46 struct inode *dir, *einode;
47 int err = 0; 47 int err = 0;
48 48
49 dir = check_dirty_dir_inode(F2FS_SB(inode->i_sb), pino); 49 dir = f2fs_iget(inode->i_sb, pino);
50 if (!dir) { 50 if (IS_ERR(dir)) {
51 dir = f2fs_iget(inode->i_sb, pino); 51 err = PTR_ERR(dir);
52 if (IS_ERR(dir)) { 52 goto out;
53 err = PTR_ERR(dir); 53 }
54 goto out; 54
55 } 55 if (is_inode_flag_set(F2FS_I(dir), FI_DIRTY_DIR)) {
56 set_inode_flag(F2FS_I(dir), FI_DELAY_IPUT); 56 iput(dir);
57 } else {
57 add_dirty_dir_inode(dir); 58 add_dirty_dir_inode(dir);
59 set_inode_flag(F2FS_I(dir), FI_DELAY_IPUT);
58 } 60 }
59 61
60 name.len = le32_to_cpu(raw_inode->i_namelen); 62 name.len = le32_to_cpu(raw_inode->i_namelen);