diff options
| author | Jaegeuk Kim <jaegeuk@kernel.org> | 2016-12-05 17:25:32 -0800 |
|---|---|---|
| committer | Mister Oyster <oysterized@gmail.com> | 2017-04-13 12:34:33 +0200 |
| commit | ec4042ccd21dd56d1abbff0c147dc8fed7864da0 (patch) | |
| tree | b3fb2a16bf4ad191efda88fefe393100389def71 | |
| parent | 21b87735b159fec99710067ab832cc0c708aac87 (diff) | |
f2fs: free meta pages if sanity check for ckpt is failed
This fixes missing freeing meta pages in the error case.
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
| -rw-r--r-- | fs/f2fs/checkpoint.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/fs/f2fs/checkpoint.c b/fs/f2fs/checkpoint.c index 740a54f64..0fcc52768 100644 --- a/fs/f2fs/checkpoint.c +++ b/fs/f2fs/checkpoint.c @@ -766,7 +766,7 @@ int get_valid_checkpoint(struct f2fs_sb_info *sbi) /* Sanity checking of checkpoint */ if (sanity_check_ckpt(sbi)) - goto fail_no_cp; + goto free_fail_no_cp; if (cur_page == cp1) sbi->cur_cp_pack = 1; @@ -794,6 +794,9 @@ done: f2fs_put_page(cp2, 1); return 0; +free_fail_no_cp: + f2fs_put_page(cp1, 1); + f2fs_put_page(cp2, 1); fail_no_cp: kfree(sbi->ckpt); return -EINVAL; |
