block: add blk-mq support to blk_insert_cloned_request()
If the request passed to blk_insert_cloned_request() was allocated by a blk-mq device it must be submitted using blk_mq_insert_request(). Signed-off-by: Keith Busch <keith.busch@intel.com> Signed-off-by: Mike Snitzer <snitzer@redhat.com> Signed-off-by: Jens Axboe <axboe@fb.com>
This commit is contained in:
parent
febf71588c
commit
7fb4898e0c
|
@ -2048,6 +2048,13 @@ int blk_insert_cloned_request(struct request_queue *q, struct request *rq)
|
||||||
should_fail_request(&rq->rq_disk->part0, blk_rq_bytes(rq)))
|
should_fail_request(&rq->rq_disk->part0, blk_rq_bytes(rq)))
|
||||||
return -EIO;
|
return -EIO;
|
||||||
|
|
||||||
|
if (q->mq_ops) {
|
||||||
|
if (blk_queue_io_stat(q))
|
||||||
|
blk_account_io_start(rq, true);
|
||||||
|
blk_mq_insert_request(rq, false, true, true);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
spin_lock_irqsave(q->queue_lock, flags);
|
spin_lock_irqsave(q->queue_lock, flags);
|
||||||
if (unlikely(blk_queue_dying(q))) {
|
if (unlikely(blk_queue_dying(q))) {
|
||||||
spin_unlock_irqrestore(q->queue_lock, flags);
|
spin_unlock_irqrestore(q->queue_lock, flags);
|
||||||
|
|
Loading…
Reference in New Issue