|
|
@@ -93,10 +93,9 @@ static int recover_dentry(struct inode *inode, struct page *ipage)
|
|
|
}
|
|
|
retry:
|
|
|
de = f2fs_find_entry(dir, &name, &page);
|
|
|
- if (de && inode->i_ino == le32_to_cpu(de->ino)) {
|
|
|
- clear_inode_flag(F2FS_I(inode), FI_INC_LINK);
|
|
|
+ if (de && inode->i_ino == le32_to_cpu(de->ino))
|
|
|
goto out_unmap_put;
|
|
|
- }
|
|
|
+
|
|
|
if (de) {
|
|
|
einode = f2fs_iget(inode->i_sb, le32_to_cpu(de->ino));
|
|
|
if (IS_ERR(einode)) {
|
|
|
@@ -187,11 +186,7 @@ static int find_fsync_dnodes(struct f2fs_sb_info *sbi, struct list_head *head)
|
|
|
goto next;
|
|
|
|
|
|
entry = get_fsync_inode(head, ino_of_node(page));
|
|
|
- if (entry) {
|
|
|
- if (IS_INODE(page) && is_dent_dnode(page))
|
|
|
- set_inode_flag(F2FS_I(entry->inode),
|
|
|
- FI_INC_LINK);
|
|
|
- } else {
|
|
|
+ if (!entry) {
|
|
|
if (IS_INODE(page) && is_dent_dnode(page)) {
|
|
|
err = recover_inode_page(sbi, page);
|
|
|
if (err)
|