aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJaegeuk Kim <jaegeuk@kernel.org>2016-04-18 17:07:44 -0400
committerMister Oyster <oysterized@gmail.com>2017-04-13 12:33:21 +0200
commitf31f1cc4a7c216f738b66a16dba771e9f4276ddb (patch)
treed82687d34b7009ef08f71650f0485054d9c02ca6
parent3d156398528a18eaf681a882e3834abbe5d5f538 (diff)
f2fs: issue cache flush on direct IO
Under direct IO path with O_(D)SYNC, it needs to set proper APPEND or UPDATE flags, so taht f2fs_sync_file can make its data safe. Acked-by: Chao Yu <yuchao0@huawei.com> Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org> Conflicts: fs/f2fs/data.c
-rw-r--r--fs/f2fs/data.c13
1 files changed, 11 insertions, 2 deletions
diff --git a/fs/f2fs/data.c b/fs/f2fs/data.c
index 6fae71f8e..37935bae5 100644
--- a/fs/f2fs/data.c
+++ b/fs/f2fs/data.c
@@ -673,6 +673,9 @@ next_block:
err = reserve_new_block(&dn);
} else {
err = __allocate_data_block(&dn);
+ if (!err)
+ set_inode_flag(F2FS_I(inode),
+ FI_APPEND_WRITE);
}
if (err)
goto sync_out;
@@ -1709,10 +1712,16 @@ static ssize_t f2fs_direct_IO(int rw, struct kiocb *iocb,
if (f2fs_encrypted_inode(inode) && S_ISREG(inode->i_mode))
return 0;
+ trace_f2fs_direct_IO_enter(inode, offset, count, rw);
+
err = blockdev_direct_IO(rw, iocb, inode, iov, offset, nr_segs,
get_data_block_dio);
- if (err < 0 && (rw & WRITE))
- f2fs_write_failed(mapping, offset + count);
+ if (err < 0 && (rw & WRITE)) {
+ if (err > 0)
+ set_inode_flag(F2FS_I(inode), FI_UPDATE_WRITE);
+ else if (err < 0)
+ f2fs_write_failed(mapping, offset + count);
+ }
trace_f2fs_direct_IO_exit(inode, offset, count, rw, err);