Skip to content

Commit 4498135

Browse files
bvanasschebrauner
authored andcommitted
block, fs: Restore the per-bio/request data lifetime fields
Restore support for passing data lifetime information from filesystems to block drivers. This patch reverts commit b179c98 ("block: Remove request.write_hint") and commit c75e707 ("block: remove the per-bio/request write hint"). This patch does not modify the size of struct bio because the new bi_write_hint member fills a hole in struct bio. pahole reports the following for struct bio on an x86_64 system with this patch applied: /* size: 112, cachelines: 2, members: 20 */ /* sum members: 110, holes: 1, sum holes: 2 */ /* last cacheline: 48 bytes */ Reviewed-by: Kanchan Joshi <joshi.k@samsung.com> Cc: Jens Axboe <axboe@kernel.dk> Cc: Christoph Hellwig <hch@lst.de> Signed-off-by: Bart Van Assche <bvanassche@acm.org> Link: https://lore.kernel.org/r/20240202203926.2478590-7-bvanassche@acm.org Signed-off-by: Christian Brauner <brauner@kernel.org>
1 parent ea7d898 commit 4498135

File tree

13 files changed

+34
-4
lines changed

13 files changed

+34
-4
lines changed

block/bio.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -251,6 +251,7 @@ void bio_init(struct bio *bio, struct block_device *bdev, struct bio_vec *table,
251251
bio->bi_opf = opf;
252252
bio->bi_flags = 0;
253253
bio->bi_ioprio = 0;
254+
bio->bi_write_hint = 0;
254255
bio->bi_status = 0;
255256
bio->bi_iter.bi_sector = 0;
256257
bio->bi_iter.bi_size = 0;
@@ -813,6 +814,7 @@ static int __bio_clone(struct bio *bio, struct bio *bio_src, gfp_t gfp)
813814
{
814815
bio_set_flag(bio, BIO_CLONED);
815816
bio->bi_ioprio = bio_src->bi_ioprio;
817+
bio->bi_write_hint = bio_src->bi_write_hint;
816818
bio->bi_iter = bio_src->bi_iter;
817819

818820
if (bio->bi_bdev) {

block/blk-crypto-fallback.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -172,6 +172,7 @@ static struct bio *blk_crypto_fallback_clone_bio(struct bio *bio_src)
172172
if (bio_flagged(bio_src, BIO_REMAPPED))
173173
bio_set_flag(bio, BIO_REMAPPED);
174174
bio->bi_ioprio = bio_src->bi_ioprio;
175+
bio->bi_write_hint = bio_src->bi_write_hint;
175176
bio->bi_iter.bi_sector = bio_src->bi_iter.bi_sector;
176177
bio->bi_iter.bi_size = bio_src->bi_iter.bi_size;
177178

block/blk-merge.c

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -810,6 +810,10 @@ static struct request *attempt_merge(struct request_queue *q,
810810
if (rq_data_dir(req) != rq_data_dir(next))
811811
return NULL;
812812

813+
/* Don't merge requests with different write hints. */
814+
if (req->write_hint != next->write_hint)
815+
return NULL;
816+
813817
if (req->ioprio != next->ioprio)
814818
return NULL;
815819

@@ -937,6 +941,10 @@ bool blk_rq_merge_ok(struct request *rq, struct bio *bio)
937941
if (!bio_crypt_rq_ctx_compatible(rq, bio))
938942
return false;
939943

944+
/* Don't merge requests with different write hints. */
945+
if (rq->write_hint != bio->bi_write_hint)
946+
return false;
947+
940948
if (rq->ioprio != bio_prio(bio))
941949
return false;
942950

block/blk-mq.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2585,6 +2585,7 @@ static void blk_mq_bio_to_request(struct request *rq, struct bio *bio,
25852585
rq->cmd_flags |= REQ_FAILFAST_MASK;
25862586

25872587
rq->__sector = bio->bi_iter.bi_sector;
2588+
rq->write_hint = bio->bi_write_hint;
25882589
blk_rq_bio_prep(rq, bio, nr_segs);
25892590

25902591
/* This can't fail, since GFP_NOIO includes __GFP_DIRECT_RECLAIM. */
@@ -3185,6 +3186,7 @@ int blk_rq_prep_clone(struct request *rq, struct request *rq_src,
31853186
}
31863187
rq->nr_phys_segments = rq_src->nr_phys_segments;
31873188
rq->ioprio = rq_src->ioprio;
3189+
rq->write_hint = rq_src->write_hint;
31883190

31893191
if (rq->bio && blk_crypto_rq_bio_prep(rq, rq->bio, gfp_mask) < 0)
31903192
goto free_and_out;

block/bounce.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -169,6 +169,7 @@ static struct bio *bounce_clone_bio(struct bio *bio_src)
169169
if (bio_flagged(bio_src, BIO_REMAPPED))
170170
bio_set_flag(bio, BIO_REMAPPED);
171171
bio->bi_ioprio = bio_src->bi_ioprio;
172+
bio->bi_write_hint = bio_src->bi_write_hint;
172173
bio->bi_iter.bi_sector = bio_src->bi_iter.bi_sector;
173174
bio->bi_iter.bi_size = bio_src->bi_iter.bi_size;
174175

block/fops.c

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -73,6 +73,7 @@ static ssize_t __blkdev_direct_IO_simple(struct kiocb *iocb,
7373
bio_init(&bio, bdev, vecs, nr_pages, dio_bio_write_op(iocb));
7474
}
7575
bio.bi_iter.bi_sector = pos >> SECTOR_SHIFT;
76+
bio.bi_write_hint = file_inode(iocb->ki_filp)->i_write_hint;
7677
bio.bi_ioprio = iocb->ki_ioprio;
7778

7879
ret = bio_iov_iter_get_pages(&bio, iter);
@@ -203,6 +204,7 @@ static ssize_t __blkdev_direct_IO(struct kiocb *iocb, struct iov_iter *iter,
203204

204205
for (;;) {
205206
bio->bi_iter.bi_sector = pos >> SECTOR_SHIFT;
207+
bio->bi_write_hint = file_inode(iocb->ki_filp)->i_write_hint;
206208
bio->bi_private = dio;
207209
bio->bi_end_io = blkdev_bio_end_io;
208210
bio->bi_ioprio = iocb->ki_ioprio;
@@ -321,6 +323,7 @@ static ssize_t __blkdev_direct_IO_async(struct kiocb *iocb,
321323
dio->flags = 0;
322324
dio->iocb = iocb;
323325
bio->bi_iter.bi_sector = pos >> SECTOR_SHIFT;
326+
bio->bi_write_hint = file_inode(iocb->ki_filp)->i_write_hint;
324327
bio->bi_end_io = blkdev_bio_end_io_async;
325328
bio->bi_ioprio = iocb->ki_ioprio;
326329

fs/buffer.c

Lines changed: 8 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -55,7 +55,7 @@
5555

5656
static int fsync_buffers_list(spinlock_t *lock, struct list_head *list);
5757
static void submit_bh_wbc(blk_opf_t opf, struct buffer_head *bh,
58-
struct writeback_control *wbc);
58+
enum rw_hint hint, struct writeback_control *wbc);
5959

6060
#define BH_ENTRY(list) list_entry((list), struct buffer_head, b_assoc_buffers)
6161

@@ -1889,7 +1889,8 @@ int __block_write_full_folio(struct inode *inode, struct folio *folio,
18891889
do {
18901890
struct buffer_head *next = bh->b_this_page;
18911891
if (buffer_async_write(bh)) {
1892-
submit_bh_wbc(REQ_OP_WRITE | write_flags, bh, wbc);
1892+
submit_bh_wbc(REQ_OP_WRITE | write_flags, bh,
1893+
inode->i_write_hint, wbc);
18931894
nr_underway++;
18941895
}
18951896
bh = next;
@@ -1944,7 +1945,8 @@ int __block_write_full_folio(struct inode *inode, struct folio *folio,
19441945
struct buffer_head *next = bh->b_this_page;
19451946
if (buffer_async_write(bh)) {
19461947
clear_buffer_dirty(bh);
1947-
submit_bh_wbc(REQ_OP_WRITE | write_flags, bh, wbc);
1948+
submit_bh_wbc(REQ_OP_WRITE | write_flags, bh,
1949+
inode->i_write_hint, wbc);
19481950
nr_underway++;
19491951
}
19501952
bh = next;
@@ -2756,6 +2758,7 @@ static void end_bio_bh_io_sync(struct bio *bio)
27562758
}
27572759

27582760
static void submit_bh_wbc(blk_opf_t opf, struct buffer_head *bh,
2761+
enum rw_hint write_hint,
27592762
struct writeback_control *wbc)
27602763
{
27612764
const enum req_op op = opf & REQ_OP_MASK;
@@ -2783,6 +2786,7 @@ static void submit_bh_wbc(blk_opf_t opf, struct buffer_head *bh,
27832786
fscrypt_set_bio_crypt_ctx_bh(bio, bh, GFP_NOIO);
27842787

27852788
bio->bi_iter.bi_sector = bh->b_blocknr * (bh->b_size >> 9);
2789+
bio->bi_write_hint = write_hint;
27862790

27872791
__bio_add_page(bio, bh->b_page, bh->b_size, bh_offset(bh));
27882792

@@ -2802,7 +2806,7 @@ static void submit_bh_wbc(blk_opf_t opf, struct buffer_head *bh,
28022806

28032807
void submit_bh(blk_opf_t opf, struct buffer_head *bh)
28042808
{
2805-
submit_bh_wbc(opf, bh, NULL);
2809+
submit_bh_wbc(opf, bh, WRITE_LIFE_NOT_SET, NULL);
28062810
}
28072811
EXPORT_SYMBOL(submit_bh);
28082812

fs/direct-io.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -410,6 +410,8 @@ dio_bio_alloc(struct dio *dio, struct dio_submit *sdio,
410410
bio->bi_end_io = dio_bio_end_io;
411411
if (dio->is_pinned)
412412
bio_set_flag(bio, BIO_PAGE_PINNED);
413+
bio->bi_write_hint = file_inode(dio->iocb->ki_filp)->i_write_hint;
414+
413415
sdio->bio = bio;
414416
sdio->logical_offset_in_bio = sdio->cur_page_fs_offset;
415417
}

fs/iomap/buffered-io.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1667,6 +1667,7 @@ iomap_alloc_ioend(struct inode *inode, struct iomap_writepage_ctx *wpc,
16671667
REQ_OP_WRITE | wbc_to_write_flags(wbc),
16681668
GFP_NOFS, &iomap_ioend_bioset);
16691669
bio->bi_iter.bi_sector = sector;
1670+
bio->bi_write_hint = inode->i_write_hint;
16701671
wbc_init_bio(wbc, bio);
16711672

16721673
ioend = container_of(bio, struct iomap_ioend, io_inline_bio);

fs/iomap/direct-io.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -380,6 +380,7 @@ static loff_t iomap_dio_bio_iter(const struct iomap_iter *iter,
380380
fscrypt_set_bio_crypt_ctx(bio, inode, pos >> inode->i_blkbits,
381381
GFP_KERNEL);
382382
bio->bi_iter.bi_sector = iomap_sector(iomap, pos);
383+
bio->bi_write_hint = inode->i_write_hint;
383384
bio->bi_ioprio = dio->iocb->ki_ioprio;
384385
bio->bi_private = dio;
385386
bio->bi_end_io = iomap_dio_bio_end_io;

0 commit comments

Comments
 (0)