summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSheng Yong <shengyong1@huawei.com>2018-12-04 22:59:21 +0800
committerJaegeuk Kim <jaegeuk@kernel.org>2018-12-14 06:38:12 -0800
commit2062e0c3daa0bcfc806f4f7331f8bba16dd42632 (patch)
treed61cbd5ef7b23f9bdbdb8ed70ce1ba475ad10495
parent0cd6d9b0d23416af3bfb8736f8be5bb66bc8060b (diff)
downloadlinux-2062e0c3daa0bcfc806f4f7331f8bba16dd42632.tar.bz2
f2fs: clear PG_writeback if IPU failed
If IPU failed, nothing is commited, we should end page writeback. Signed-off-by: Sheng Yong <shengyong1@huawei.com> Reviewed-by: Chao Yu <yuchao0@huawei.com> Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
-rw-r--r--fs/f2fs/data.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/fs/f2fs/data.c b/fs/f2fs/data.c
index 7ddc0e57468c..fd3a1e5ab6d9 100644
--- a/fs/f2fs/data.c
+++ b/fs/f2fs/data.c
@@ -1860,6 +1860,8 @@ got_it:
if (fio->need_lock == LOCK_REQ)
f2fs_unlock_op(fio->sbi);
err = f2fs_inplace_write_data(fio);
+ if (err && PageWriteback(page))
+ end_page_writeback(page);
trace_f2fs_do_write_data_page(fio->page, IPU);
set_inode_flag(inode, FI_UPDATE_WRITE);
return err;