We should put the inode page when error was occurred.

Signed-off-by: Jaegeuk Kim <jaeg...@kernel.org>
---
 fs/f2fs/data.c | 10 ++++++----
 1 file changed, 6 insertions(+), 4 deletions(-)

diff --git a/fs/f2fs/data.c b/fs/f2fs/data.c
index 8f16443..12dd58a 100644
--- a/fs/f2fs/data.c
+++ b/fs/f2fs/data.c
@@ -963,22 +963,22 @@ repeat:
                } else if (page->index == 0) {
                        err = f2fs_convert_inline_page(&dn, page);
                        if (err)
-                               goto unlock_fail;
+                               goto put_fail;
                } else {
                        struct page *p = grab_cache_page(inode->i_mapping, 0);
                        if (!p) {
                                err = -ENOMEM;
-                               goto unlock_fail;
+                               goto put_fail;
                        }
                        err = f2fs_convert_inline_page(&dn, p);
                        f2fs_put_page(p, 1);
                        if (err)
-                               goto unlock_fail;
+                               goto put_fail;
                }
        }
        err = f2fs_reserve_block(&dn, index);
        if (err)
-               goto unlock_fail;
+               goto put_fail;
 put_next:
        f2fs_put_dnode(&dn);
        f2fs_unlock_op(sbi);
@@ -1021,6 +1021,8 @@ out:
        clear_cold_data(page);
        return 0;
 
+put_fail:
+       f2fs_put_dnode(&dn);
 unlock_fail:
        f2fs_unlock_op(sbi);
        f2fs_put_page(page, 1);
-- 
2.1.1

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to