summaryrefslogtreecommitdiff
path: root/block
diff options
context:
space:
mode:
authorChristoph Hellwig <hch@lst.de>2023-05-20 06:45:03 +0200
committerJens Axboe <axboe@kernel.dk>2023-05-20 05:42:41 -0600
commit712c7364655f69827d0b96f69594886ecbfb412f (patch)
tree63f72f900a3b51cf043b0c8fd21648d9ebbeabf2 /block
parentf80dd11dd1d07ada04a9fcd57032fa82e136462d (diff)
downloadlwn-712c7364655f69827d0b96f69594886ecbfb412f.tar.gz
lwn-712c7364655f69827d0b96f69594886ecbfb412f.zip
block: don't plug in blkdev_write_iter
For direct I/O writes that issues more than a single bio, the plugging is already done in __blkdev_direct_IO. For synchronous buffered writes the plugging is done deep down in writeback_inodes_wb / wb_writeback. For the other cases there is no point in plugging as as single bio or no bio at all is submitted. Signed-off-by: Christoph Hellwig <hch@lst.de> Link: https://lore.kernel.org/r/20230520044503.334444-1-hch@lst.de Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'block')
-rw-r--r--block/fops.c3
1 files changed, 0 insertions, 3 deletions
diff --git a/block/fops.c b/block/fops.c
index d2e6be4e3d1c..102ee85fc6ee 100644
--- a/block/fops.c
+++ b/block/fops.c
@@ -520,7 +520,6 @@ static ssize_t blkdev_write_iter(struct kiocb *iocb, struct iov_iter *from)
struct block_device *bdev = iocb->ki_filp->private_data;
struct inode *bd_inode = bdev->bd_inode;
loff_t size = bdev_nr_bytes(bdev);
- struct blk_plug plug;
size_t shorted = 0;
ssize_t ret;
@@ -545,12 +544,10 @@ static ssize_t blkdev_write_iter(struct kiocb *iocb, struct iov_iter *from)
iov_iter_truncate(from, size);
}
- blk_start_plug(&plug);
ret = __generic_file_write_iter(iocb, from);
if (ret > 0)
ret = generic_write_sync(iocb, ret);
iov_iter_reexpand(from, iov_iter_count(from) + shorted);
- blk_finish_plug(&plug);
return ret;
}