f2fs: fix error path handling in truncate_dnode()
authorChao Yu <chao@kernel.org>
Thu, 29 Jun 2023 01:41:02 +0000 (09:41 +0800)
committerJaegeuk Kim <jaegeuk@kernel.org>
Fri, 30 Jun 2023 23:38:27 +0000 (16:38 -0700)
If truncate_node() fails in truncate_dnode(), it missed to call
f2fs_put_page(), fix it.

Fixes: 7735730d39d7 ("f2fs: fix to propagate error from __get_meta_page()")
Signed-off-by: Chao Yu <chao@kernel.org>
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
fs/f2fs/node.c

index 4a105a0cd79438ca48f3859136a9c85b1ac20bb3..dadea6b01888c973e7cda2037127a194d25445cb 100644 (file)
@@ -943,8 +943,10 @@ static int truncate_dnode(struct dnode_of_data *dn)
        dn->ofs_in_node = 0;
        f2fs_truncate_data_blocks(dn);
        err = truncate_node(dn);
-       if (err)
+       if (err) {
+               f2fs_put_page(page, 1);
                return err;
+       }
 
        return 1;
 }