public inbox for linux-block@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH, RFC] block: set noio context in submit_bio_noacct_nocheck
@ 2024-01-24  9:39 Christoph Hellwig
  2024-01-24 15:40 ` Jens Axboe
  0 siblings, 1 reply; 7+ messages in thread
From: Christoph Hellwig @ 2024-01-24  9:39 UTC (permalink / raw)
  To: axboe; +Cc: linux-block, tj, jiangshanlai, linux-kernel

Make sure all in-line block layer submission runs in noio reclaim
context.  This is a big step towards allowing GFP_NOIO, the other
one would be to have noio (and nofs for that matter) workqueues for
kblockd and driver internal workqueues.

Signed-off-by: Christoph Hellwig <hch@lst.de>
---
 block/blk-core.c | 4 ++++
 1 file changed, 4 insertions(+)

diff --git a/block/blk-core.c b/block/blk-core.c
index 11342af420d0c4..b85ef8a0fdf6a0 100644
--- a/block/blk-core.c
+++ b/block/blk-core.c
@@ -691,6 +691,8 @@ static void __submit_bio_noacct_mq(struct bio *bio)
 
 void submit_bio_noacct_nocheck(struct bio *bio)
 {
+	unsigned int noio_flag = memalloc_noio_save();
+
 	blk_cgroup_bio_start(bio);
 	blkcg_bio_issue_init(bio);
 
@@ -715,6 +717,8 @@ void submit_bio_noacct_nocheck(struct bio *bio)
 		__submit_bio_noacct_mq(bio);
 	else
 		__submit_bio_noacct(bio);
+
+	memalloc_noio_restore(noio_flag);
 }
 
 /**
-- 
2.39.2


^ permalink raw reply related	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2024-01-26 13:52 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-01-24  9:39 [PATCH, RFC] block: set noio context in submit_bio_noacct_nocheck Christoph Hellwig
2024-01-24 15:40 ` Jens Axboe
2024-01-25  8:10   ` Christoph Hellwig
2024-01-25 16:09     ` Jens Axboe
2024-01-25 16:11       ` Matthew Wilcox
2024-01-25 16:13         ` Jens Axboe
2024-01-26 13:52           ` Christoph Hellwig

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox