aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJaegeuk Kim <jaegeuk@kernel.org>2014-08-29 11:26:57 -0700
committerJaegeuk Kim <jaegeuk@kernel.org>2014-08-29 13:43:29 -0700
commit32edfeaac782dd7c9583eacf098e5794df341f07 (patch)
tree327457df6660195ac49ff0ad8886bee1c9416d85
parent48ffea7ba8669f372cb372f870a12e6faf02bc36 (diff)
downloadandroid_external_f2fs-tools-32edfeaac782dd7c9583eacf098e5794df341f07.tar.gz
android_external_f2fs-tools-32edfeaac782dd7c9583eacf098e5794df341f07.tar.bz2
android_external_f2fs-tools-32edfeaac782dd7c9583eacf098e5794df341f07.zip
fsck.f2fs: remove dentry if its inode block is corrupted
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
-rw-r--r--fsck/fsck.c17
1 files changed, 15 insertions, 2 deletions
diff --git a/fsck/fsck.c b/fsck/fsck.c
index 00f5b27..2a47b4c 100644
--- a/fsck/fsck.c
+++ b/fsck/fsck.c
@@ -617,8 +617,21 @@ int fsck_chk_dentry_blk(struct f2fs_sb_info *sbi, u32 blk_addr,
TYPE_INODE,
&blk_cnt);
- if (ret)
- printf("TODO: delete dentry\n");
+ if (ret && config.fix_cnt) {
+ int j;
+ int slots = (name_len + F2FS_SLOT_LEN - 1) /
+ F2FS_SLOT_LEN;
+ for (j = 0; j < slots; j++)
+ clear_bit(i + j,
+ (unsigned long *)de_blk->dentry_bitmap);
+ FIX_MSG("Unlink [0x%x] - %s len[0x%x], type[0x%x]",
+ le32_to_cpu(de_blk->dentry[i].ino),
+ name, name_len,
+ de_blk->dentry[i].file_type);
+ i += slots;
+ free(name);
+ continue;
+ }
i += (name_len + F2FS_SLOT_LEN - 1) / F2FS_SLOT_LEN;
dentries++;