@@ -2139,6 +2139,21 @@ static void blk_mq_map_swqueue(struct request_queue *q,
}
}
+/*
+ * Queue depth can be changed via blk_mq_update_nr_requests(),
+ * so use this helper to retrieve queue's depth.
+ */
+int blk_mq_get_queue_depth(struct request_queue *q)
+{
+ /*
+ * All queues have same queue depth, need to revisit
+ * if per hw-queue depth is supported.
+ */
+ struct blk_mq_tags *tags = q->tag_set->tags[0];
+
+ return tags->bitmap_tags.sb.depth + tags->breserved_tags.sb.depth;
+}
+
static void queue_set_hctx_shared(struct request_queue *q, bool shared)
{
struct blk_mq_hw_ctx *hctx;
@@ -138,6 +138,7 @@ void __blk_mq_finish_request(struct blk_mq_hw_ctx *hctx, struct blk_mq_ctx *ctx,
void blk_mq_finish_request(struct request *rq);
struct request *__blk_mq_alloc_request(struct blk_mq_alloc_data *data,
unsigned int op);
+int blk_mq_get_queue_depth(struct request_queue *q);
static inline bool blk_mq_hctx_stopped(struct blk_mq_hw_ctx *hctx)
{