diff options
author | Jens Axboe <axboe@kernel.dk> | 2019-01-27 08:35:28 -0500 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2019-01-27 08:35:28 -0500 |
commit | 947b7ac135b16aa60f9141ff72bd494eda0edb5e (patch) | |
tree | 1b0d82a312636fdf683ef2eeab3b288df6f4f6fd /block/blk-merge.c | |
parent | 8367de2c99a13d35960a51d6084631c883e93a4d (diff) |
Revert "block: cover another queue enter recursion via BIO_QUEUE_ENTERED"
We can't touch a bio after ->make_request_fn(), for all we know it could
already have been completed by the time this function returns.
This reverts commit 698cef173983b086977e633e46476e0f925ca01e.
Reported-by: syzbot+4df6ca820108fd248943@syzkaller.appspotmail.com
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'block/blk-merge.c')
-rw-r--r-- | block/blk-merge.c | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/block/blk-merge.c b/block/blk-merge.c index d79a22f111d1..71e9ac03f621 100644 --- a/block/blk-merge.c +++ b/block/blk-merge.c | |||
@@ -272,6 +272,16 @@ void blk_queue_split(struct request_queue *q, struct bio **bio) | |||
272 | /* there isn't chance to merge the splitted bio */ | 272 | /* there isn't chance to merge the splitted bio */ |
273 | split->bi_opf |= REQ_NOMERGE; | 273 | split->bi_opf |= REQ_NOMERGE; |
274 | 274 | ||
275 | /* | ||
276 | * Since we're recursing into make_request here, ensure | ||
277 | * that we mark this bio as already having entered the queue. | ||
278 | * If not, and the queue is going away, we can get stuck | ||
279 | * forever on waiting for the queue reference to drop. But | ||
280 | * that will never happen, as we're already holding a | ||
281 | * reference to it. | ||
282 | */ | ||
283 | bio_set_flag(*bio, BIO_QUEUE_ENTERED); | ||
284 | |||
275 | bio_chain(split, *bio); | 285 | bio_chain(split, *bio); |
276 | trace_block_split(q, split, (*bio)->bi_iter.bi_sector); | 286 | trace_block_split(q, split, (*bio)->bi_iter.bi_sector); |
277 | generic_make_request(*bio); | 287 | generic_make_request(*bio); |