The only caller of blk_mq_start_stopped_hw_queues is in irq context, leading to lockdep splat when it actually gets called. Fix this by deferring the hw queue run to workqueue context.
Signed-off-by: Christoph Hellwig <h...@lst.de> diff --git a/block/blk-mq.c b/block/blk-mq.c index 2b85029..923e9e1 100644 --- a/block/blk-mq.c +++ b/block/blk-mq.c @@ -686,7 +686,8 @@ void blk_mq_start_stopped_hw_queues(struct request_queue *q) if (!test_bit(BLK_MQ_S_STOPPED, &hctx->state)) continue; - blk_mq_start_hw_queue(hctx); + clear_bit(BLK_MQ_S_STOPPED, &hctx->state); + blk_mq_run_hw_queue(hctx, true); } } EXPORT_SYMBOL(blk_mq_start_stopped_hw_queues); -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/