diff options
author | Christoph Hellwig <hch@lst.de> | 2018-06-19 18:40:14 +0200 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2018-06-19 19:27:18 +0200 |
commit | 0cc61e64e21cfc24fa0d938fd148aba4a595163b (patch) | |
tree | 51eab03835e134bfc48d588ea268d1580ebfd3d3 /drivers/block | |
parent | bsg: fix race of bsg_open and bsg_unregister (diff) | |
download | linux-0cc61e64e21cfc24fa0d938fd148aba4a595163b.tar.xz linux-0cc61e64e21cfc24fa0d938fd148aba4a595163b.zip |
block: fix timeout changes for legacy request drivers
blk_mq_complete_request can only be called for blk-mq drivers, but when
removing the BLK_EH_HANDLED return value, two legacy request timeout
methods incorrectly got switched to call blk_mq_complete_request.
Call __blk_complete_request instead to reinstance the previous behavior.
For that __blk_complete_request needs to be exported.
Fixes: 1fc2b62e ("scsi_transport_fc: complete requests from ->timeout")
Fixes: 0df0bb08 ("null_blk: complete requests from ->timeout")
Reported-by: Jianchao Wang <jianchao.w.wang@oracle.com>
Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'drivers/block')
-rw-r--r-- | drivers/block/null_blk.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/block/null_blk.c b/drivers/block/null_blk.c index 2bdadd7f1454..3d8bdbe9bd35 100644 --- a/drivers/block/null_blk.c +++ b/drivers/block/null_blk.c @@ -1365,7 +1365,7 @@ static blk_qc_t null_queue_bio(struct request_queue *q, struct bio *bio) static enum blk_eh_timer_return null_rq_timed_out_fn(struct request *rq) { pr_info("null: rq %p timed out\n", rq); - blk_mq_complete_request(rq); + __blk_complete_request(rq); return BLK_EH_DONE; } |