linux-block.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* Re: [PATCH] bcache: call bio_endio() to replace directly calling bio->bi_end_io()
@ 2025-12-01  2:49 Stephen Zhang
  2025-12-01  5:42 ` Coly Li
  0 siblings, 1 reply; 3+ messages in thread
From: Stephen Zhang @ 2025-12-01  2:49 UTC (permalink / raw)
  To: Coly Li
  Cc: baijiaju1990, Christoph Hellwig, linux-bcache, linux-block,
	stable, zhangshida

Hi Coly,

For this issue, I've previously sent a fix here:
https://lore.kernel.org/all/20251129090122.2457896-2-zhangshida@kylinos.cn/
Would you be able to take a look and see if that one is suitable to pick up?

Thanks,
Shida

^ permalink raw reply	[flat|nested] 3+ messages in thread
* [PATCH] bcache: call bio_endio() to replace directly calling bio->bi_end_io()
@ 2025-11-30 15:08 colyli
  0 siblings, 0 replies; 3+ messages in thread
From: colyli @ 2025-11-30 15:08 UTC (permalink / raw)
  To: linux-bcache, linux-block
  Cc: Coly Li, Shida Zhang, Christoph Hellwig, Jia-Ju Bai, stable

From: Coly Li <colyli@fnnas.com>

When a bcache device is not attached to a cache device, current code
calls the request's bi_end_io() callback directly. The correct method is
to call bio_endio(bio) instead of bio->bi_end_io(bio).

This patch fixes the incorrect calling.

Fixes: bc082a55d25c ("bcache: fix inaccurate io state for detached bcache devices")
Fixes: 40f567bbb3b0 ("md: bcache: check the return value of kzalloc() in detached_dev_do_request()")
Reported-by: Shida Zhang <zhangshida@kylinos.cn>
Closes: https://lore.kernel.org/linux-block/20251121081748.1443507-1-zhangshida@kylinos.cn/
Cc: Christoph Hellwig <hch@infradead.org>
Cc: Jia-Ju Bai <baijiaju1990@gmail.com>
Cc: stable@vger.kernel.org #4.17+
Signed-off-by: Coly Li <colyli@fnnas.com>
---
 drivers/md/bcache/request.c | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)

diff --git a/drivers/md/bcache/request.c b/drivers/md/bcache/request.c
index af345dc6fde1..7b815064db54 100644
--- a/drivers/md/bcache/request.c
+++ b/drivers/md/bcache/request.c
@@ -1104,7 +1104,7 @@ static void detached_dev_end_io(struct bio *bio)
 	}
 
 	kfree(ddip);
-	bio->bi_end_io(bio);
+	bio_endio(bio);
 }
 
 static void detached_dev_do_request(struct bcache_device *d, struct bio *bio,
@@ -1121,7 +1121,7 @@ static void detached_dev_do_request(struct bcache_device *d, struct bio *bio,
 	ddip = kzalloc(sizeof(struct detached_dev_io_private), GFP_NOIO);
 	if (!ddip) {
 		bio->bi_status = BLK_STS_RESOURCE;
-		bio->bi_end_io(bio);
+		bio_endio(bio);
 		return;
 	}
 
@@ -1136,7 +1136,7 @@ static void detached_dev_do_request(struct bcache_device *d, struct bio *bio,
 
 	if ((bio_op(bio) == REQ_OP_DISCARD) &&
 	    !bdev_max_discard_sectors(dc->bdev))
-		bio->bi_end_io(bio);
+		bio_endio(bio);
 	else
 		submit_bio_noacct(bio);
 }
-- 
2.47.3


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

end of thread, other threads:[~2025-12-01  5:42 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-12-01  2:49 [PATCH] bcache: call bio_endio() to replace directly calling bio->bi_end_io() Stephen Zhang
2025-12-01  5:42 ` Coly Li
  -- strict thread matches above, loose matches on Subject: below --
2025-11-30 15:08 colyli

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).