blk-mq: stop hardware queue in blk_mq_delay_queue()
authorJens Axboe <axboe@fb.com>
Thu, 19 Jan 2017 14:58:59 +0000 (07:58 -0700)
committerJens Axboe <axboe@fb.com>
Thu, 19 Jan 2017 15:01:55 +0000 (08:01 -0700)
The run handler we register for the delayed work requires that the
queue be stopped, yet we leave that up to the caller. Let's move
it into blk_mq_delay_queue() itself, so that the API is sane.

This fixes a stall with SCSI, where it calls blk_mq_delay_queue()
without having stopped the queue. Hence the queue is never run.

Reported-by: Hannes Reinecke <hare@suse.com>
Fixes: 70f4db639c5b ("blk-mq: add blk_mq_delay_queue")
Signed-off-by: Jens Axboe <axboe@fb.com>
block/blk-mq.c

index fa1f8619bfe7dbbba9422288d7ddb07011a6e919..b365cde4c909c623cbbc7480db0c253e483451f5 100644 (file)
@@ -1170,6 +1170,7 @@ void blk_mq_delay_queue(struct blk_mq_hw_ctx *hctx, unsigned long msecs)
        if (unlikely(!blk_mq_hw_queue_mapped(hctx)))
                return;
 
+       blk_mq_stop_hw_queue(hctx);
        kblockd_schedule_delayed_work_on(blk_mq_hctx_next_cpu(hctx),
                        &hctx->delay_work, msecs_to_jiffies(msecs));
 }