iocb: delay evaluation of IS_SYNC(...) until we want to check IOCB_DSYNC
New helper to be used instead of direct checks for IOCB_DSYNC: iocb_is_dsync(iocb). Checks converted, which allows to avoid the IS_SYNC(iocb->ki_filp->f_mapping->host) part (4 cache lines) from iocb_flags() - it's checked in iocb_is_dsync() instead Reviewed-by: Christian Brauner (Microsoft) <brauner@kernel.org> Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
parent
e87f2c26c8
commit
91b94c5d6a
|
@ -37,7 +37,7 @@ static unsigned int dio_bio_write_op(struct kiocb *iocb)
|
||||||
unsigned int op = REQ_OP_WRITE | REQ_SYNC | REQ_IDLE;
|
unsigned int op = REQ_OP_WRITE | REQ_SYNC | REQ_IDLE;
|
||||||
|
|
||||||
/* avoid the need for a I/O completion work item */
|
/* avoid the need for a I/O completion work item */
|
||||||
if (iocb->ki_flags & IOCB_DSYNC)
|
if (iocb_is_dsync(iocb))
|
||||||
op |= REQ_FUA;
|
op |= REQ_FUA;
|
||||||
return op;
|
return op;
|
||||||
}
|
}
|
||||||
|
|
|
@ -2021,7 +2021,7 @@ ssize_t btrfs_do_write_iter(struct kiocb *iocb, struct iov_iter *from,
|
||||||
struct file *file = iocb->ki_filp;
|
struct file *file = iocb->ki_filp;
|
||||||
struct btrfs_inode *inode = BTRFS_I(file_inode(file));
|
struct btrfs_inode *inode = BTRFS_I(file_inode(file));
|
||||||
ssize_t num_written, num_sync;
|
ssize_t num_written, num_sync;
|
||||||
const bool sync = iocb->ki_flags & IOCB_DSYNC;
|
const bool sync = iocb_is_dsync(iocb);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If the fs flips readonly due to some impossible error, although we
|
* If the fs flips readonly due to some impossible error, although we
|
||||||
|
|
|
@ -1210,7 +1210,7 @@ ssize_t __blockdev_direct_IO(struct kiocb *iocb, struct inode *inode,
|
||||||
*/
|
*/
|
||||||
if (dio->is_async && iov_iter_rw(iter) == WRITE) {
|
if (dio->is_async && iov_iter_rw(iter) == WRITE) {
|
||||||
retval = 0;
|
retval = 0;
|
||||||
if (iocb->ki_flags & IOCB_DSYNC)
|
if (iocb_is_dsync(iocb))
|
||||||
retval = dio_set_defer_completion(dio);
|
retval = dio_set_defer_completion(dio);
|
||||||
else if (!dio->inode->i_sb->s_dio_done_wq) {
|
else if (!dio->inode->i_sb->s_dio_done_wq) {
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -1042,7 +1042,7 @@ static unsigned int fuse_write_flags(struct kiocb *iocb)
|
||||||
{
|
{
|
||||||
unsigned int flags = iocb->ki_filp->f_flags;
|
unsigned int flags = iocb->ki_filp->f_flags;
|
||||||
|
|
||||||
if (iocb->ki_flags & IOCB_DSYNC)
|
if (iocb_is_dsync(iocb))
|
||||||
flags |= O_DSYNC;
|
flags |= O_DSYNC;
|
||||||
if (iocb->ki_flags & IOCB_SYNC)
|
if (iocb->ki_flags & IOCB_SYNC)
|
||||||
flags |= O_SYNC;
|
flags |= O_SYNC;
|
||||||
|
|
|
@ -548,8 +548,7 @@ __iomap_dio_rw(struct kiocb *iocb, struct iov_iter *iter,
|
||||||
}
|
}
|
||||||
|
|
||||||
/* for data sync or sync, we need sync completion processing */
|
/* for data sync or sync, we need sync completion processing */
|
||||||
if (iocb->ki_flags & IOCB_DSYNC &&
|
if (iocb_is_dsync(iocb) && !(dio_flags & IOMAP_DIO_NOSYNC)) {
|
||||||
!(dio_flags & IOMAP_DIO_NOSYNC)) {
|
|
||||||
dio->flags |= IOMAP_DIO_NEED_SYNC;
|
dio->flags |= IOMAP_DIO_NEED_SYNC;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -746,7 +746,7 @@ static ssize_t zonefs_file_dio_append(struct kiocb *iocb, struct iov_iter *from)
|
||||||
REQ_OP_ZONE_APPEND | REQ_SYNC | REQ_IDLE, GFP_NOFS);
|
REQ_OP_ZONE_APPEND | REQ_SYNC | REQ_IDLE, GFP_NOFS);
|
||||||
bio->bi_iter.bi_sector = zi->i_zsector;
|
bio->bi_iter.bi_sector = zi->i_zsector;
|
||||||
bio->bi_ioprio = iocb->ki_ioprio;
|
bio->bi_ioprio = iocb->ki_ioprio;
|
||||||
if (iocb->ki_flags & IOCB_DSYNC)
|
if (iocb_is_dsync(iocb))
|
||||||
bio->bi_opf |= REQ_FUA;
|
bio->bi_opf |= REQ_FUA;
|
||||||
|
|
||||||
ret = bio_iov_iter_get_pages(bio, from);
|
ret = bio_iov_iter_get_pages(bio, from);
|
||||||
|
|
|
@ -2720,6 +2720,12 @@ extern int vfs_fsync(struct file *file, int datasync);
|
||||||
extern int sync_file_range(struct file *file, loff_t offset, loff_t nbytes,
|
extern int sync_file_range(struct file *file, loff_t offset, loff_t nbytes,
|
||||||
unsigned int flags);
|
unsigned int flags);
|
||||||
|
|
||||||
|
static inline bool iocb_is_dsync(const struct kiocb *iocb)
|
||||||
|
{
|
||||||
|
return (iocb->ki_flags & IOCB_DSYNC) ||
|
||||||
|
IS_SYNC(iocb->ki_filp->f_mapping->host);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Sync the bytes written if this was a synchronous write. Expect ki_pos
|
* Sync the bytes written if this was a synchronous write. Expect ki_pos
|
||||||
* to already be updated for the write, and will return either the amount
|
* to already be updated for the write, and will return either the amount
|
||||||
|
@ -2727,7 +2733,7 @@ extern int sync_file_range(struct file *file, loff_t offset, loff_t nbytes,
|
||||||
*/
|
*/
|
||||||
static inline ssize_t generic_write_sync(struct kiocb *iocb, ssize_t count)
|
static inline ssize_t generic_write_sync(struct kiocb *iocb, ssize_t count)
|
||||||
{
|
{
|
||||||
if (iocb->ki_flags & IOCB_DSYNC) {
|
if (iocb_is_dsync(iocb)) {
|
||||||
int ret = vfs_fsync_range(iocb->ki_filp,
|
int ret = vfs_fsync_range(iocb->ki_filp,
|
||||||
iocb->ki_pos - count, iocb->ki_pos - 1,
|
iocb->ki_pos - count, iocb->ki_pos - 1,
|
||||||
(iocb->ki_flags & IOCB_SYNC) ? 0 : 1);
|
(iocb->ki_flags & IOCB_SYNC) ? 0 : 1);
|
||||||
|
@ -3262,7 +3268,7 @@ static inline int iocb_flags(struct file *file)
|
||||||
res |= IOCB_APPEND;
|
res |= IOCB_APPEND;
|
||||||
if (file->f_flags & O_DIRECT)
|
if (file->f_flags & O_DIRECT)
|
||||||
res |= IOCB_DIRECT;
|
res |= IOCB_DIRECT;
|
||||||
if ((file->f_flags & O_DSYNC) || IS_SYNC(file->f_mapping->host))
|
if (file->f_flags & O_DSYNC)
|
||||||
res |= IOCB_DSYNC;
|
res |= IOCB_DSYNC;
|
||||||
if (file->f_flags & __O_SYNC)
|
if (file->f_flags & __O_SYNC)
|
||||||
res |= IOCB_SYNC;
|
res |= IOCB_SYNC;
|
||||||
|
|
Loading…
Reference in New Issue