Commit 843477d4 authored by Jens Axboe's avatar Jens Axboe

blk-mq: initial support for multiple queue maps

Add a queue offset to the tag map. This enables users to map
iteratively, for each queue map type they support.

Bump maximum number of supported maps to 2, we're now fully
able to support more than 1 map.
Reviewed-by: default avatarHannes Reinecke <hare@suse.com>
Reviewed-by: default avatarKeith Busch <keith.busch@intel.com>
Reviewed-by: default avatarSagi Grimberg <sagi@grimberg.me>
Signed-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent 3110fc79
...@@ -14,9 +14,10 @@ ...@@ -14,9 +14,10 @@
#include "blk.h" #include "blk.h"
#include "blk-mq.h" #include "blk-mq.h"
static int cpu_to_queue_index(unsigned int nr_queues, const int cpu) static int cpu_to_queue_index(struct blk_mq_queue_map *qmap,
unsigned int nr_queues, const int cpu)
{ {
return cpu % nr_queues; return qmap->queue_offset + (cpu % nr_queues);
} }
static int get_first_sibling(unsigned int cpu) static int get_first_sibling(unsigned int cpu)
...@@ -44,11 +45,11 @@ int blk_mq_map_queues(struct blk_mq_queue_map *qmap) ...@@ -44,11 +45,11 @@ int blk_mq_map_queues(struct blk_mq_queue_map *qmap)
* performace optimizations. * performace optimizations.
*/ */
if (cpu < nr_queues) { if (cpu < nr_queues) {
map[cpu] = cpu_to_queue_index(nr_queues, cpu); map[cpu] = cpu_to_queue_index(qmap, nr_queues, cpu);
} else { } else {
first_sibling = get_first_sibling(cpu); first_sibling = get_first_sibling(cpu);
if (first_sibling == cpu) if (first_sibling == cpu)
map[cpu] = cpu_to_queue_index(nr_queues, cpu); map[cpu] = cpu_to_queue_index(qmap, nr_queues, cpu);
else else
map[cpu] = map[first_sibling]; map[cpu] = map[first_sibling];
} }
......
...@@ -43,7 +43,7 @@ int blk_mq_pci_map_queues(struct blk_mq_queue_map *qmap, struct pci_dev *pdev, ...@@ -43,7 +43,7 @@ int blk_mq_pci_map_queues(struct blk_mq_queue_map *qmap, struct pci_dev *pdev,
goto fallback; goto fallback;
for_each_cpu(cpu, mask) for_each_cpu(cpu, mask)
qmap->mq_map[cpu] = queue; qmap->mq_map[cpu] = qmap->queue_offset + queue;
} }
return 0; return 0;
......
...@@ -44,7 +44,7 @@ int blk_mq_virtio_map_queues(struct blk_mq_queue_map *qmap, ...@@ -44,7 +44,7 @@ int blk_mq_virtio_map_queues(struct blk_mq_queue_map *qmap,
goto fallback; goto fallback;
for_each_cpu(cpu, mask) for_each_cpu(cpu, mask)
qmap->mq_map[cpu] = queue; qmap->mq_map[cpu] = qmap->queue_offset + queue;
} }
return 0; return 0;
......
...@@ -78,10 +78,11 @@ struct blk_mq_hw_ctx { ...@@ -78,10 +78,11 @@ struct blk_mq_hw_ctx {
struct blk_mq_queue_map { struct blk_mq_queue_map {
unsigned int *mq_map; unsigned int *mq_map;
unsigned int nr_queues; unsigned int nr_queues;
unsigned int queue_offset;
}; };
enum { enum {
HCTX_MAX_TYPES = 1, HCTX_MAX_TYPES = 2,
}; };
struct blk_mq_tag_set { struct blk_mq_tag_set {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment