aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChao Yu <[email protected]>2017-09-12 06:04:05 +0000
committerJaegeuk Kim <[email protected]>2017-09-12 17:02:39 +0000
commitca7d802a7d8ee4c47dce9be86ef4b27e587086bb (patch)
treedc4f81b6a204dbc62c32e95ed2c4beb81d20f1e4
parentf2fs: clear radix tree dirty tag of pages whose dirty flag is cleared (diff)
downloadkernel-ca7d802a7d8ee4c47dce9be86ef4b27e587086bb.tar.gz
kernel-ca7d802a7d8ee4c47dce9be86ef4b27e587086bb.zip
f2fs: detect dirty inode in evict_inode
Add a bugon in f2fs_evict_inode to detect inconsistent status between inode cache and related node page cache. Signed-off-by: Chao Yu <[email protected]> Signed-off-by: Jaegeuk Kim <[email protected]>
-rw-r--r--fs/f2fs/inode.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/fs/f2fs/inode.c b/fs/f2fs/inode.c
index c33b05aec1a1..50c88e37ed66 100644
--- a/fs/f2fs/inode.c
+++ b/fs/f2fs/inode.c
@@ -519,6 +519,9 @@ no_delete:
stat_dec_inline_dir(inode);
stat_dec_inline_inode(inode);
+ if (!is_set_ckpt_flags(sbi, CP_ERROR_FLAG))
+ f2fs_bug_on(sbi, is_inode_flag_set(inode, FI_DIRTY_INODE));
+
/* ino == 0, if f2fs_new_inode() was failed t*/
if (inode->i_ino)
invalidate_mapping_pages(NODE_MAPPING(sbi), inode->i_ino,