diff options
author | Jaegeuk Kim <jaegeuk@kernel.org> | 2014-08-29 11:26:57 -0700 |
---|---|---|
committer | Jaegeuk Kim <jaegeuk@kernel.org> | 2014-08-29 13:43:29 -0700 |
commit | 32edfeaac782dd7c9583eacf098e5794df341f07 (patch) | |
tree | 327457df6660195ac49ff0ad8886bee1c9416d85 | |
parent | 48ffea7ba8669f372cb372f870a12e6faf02bc36 (diff) | |
download | android_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.c | 17 |
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++; |