diff options
author | Chao Yu <chao@kernel.org> | 2023-06-29 09:41:02 +0800 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2023-08-11 11:45:13 +0200 |
commit | 37f6006362a2329a8e2fb4be0df759b49f1f3a02 (patch) | |
tree | 4204e36cd79f1ed3d9d6f9be043840eaf2c478ce /fs/f2fs | |
parent | 391dcc9204560e1b5c2275f67f9cb26d5a48e511 (diff) | |
download | linux-stable-37f6006362a2329a8e2fb4be0df759b49f1f3a02.tar.gz linux-stable-37f6006362a2329a8e2fb4be0df759b49f1f3a02.tar.bz2 linux-stable-37f6006362a2329a8e2fb4be0df759b49f1f3a02.zip |
f2fs: fix error path handling in truncate_dnode()
[ Upstream commit 0135c482fa97e2fd8245cb462784112a00ed1211 ]
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>
Signed-off-by: Sasha Levin <sashal@kernel.org>
Diffstat (limited to 'fs/f2fs')
-rw-r--r-- | fs/f2fs/node.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/fs/f2fs/node.c b/fs/f2fs/node.c index 2c28f488ac2f..9911f780e013 100644 --- a/fs/f2fs/node.c +++ b/fs/f2fs/node.c @@ -879,8 +879,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; } |