mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-04 04:06:26 +00:00
scsi: add support for multiple hardware queues
Allow a SCSI LLD to declare how many hardware queues it supports by setting Scsi_Host.nr_hw_queues before calling scsi_add_host(). Signed-off-by: Bart Van Assche <bvanassche@acm.org> Reviewed-by: Sagi Grimberg <sagig@mellanox.com> Reviewed-by: Martin K. Petersen <martin.petersen@oracle.com> Signed-off-by: Christoph Hellwig <hch@lst.de>
This commit is contained in:
parent
205fb5f5ba
commit
efec4b90f1
@ -2106,7 +2106,7 @@ int scsi_mq_setup_tags(struct Scsi_Host *shost)
|
|||||||
|
|
||||||
memset(&shost->tag_set, 0, sizeof(shost->tag_set));
|
memset(&shost->tag_set, 0, sizeof(shost->tag_set));
|
||||||
shost->tag_set.ops = &scsi_mq_ops;
|
shost->tag_set.ops = &scsi_mq_ops;
|
||||||
shost->tag_set.nr_hw_queues = 1;
|
shost->tag_set.nr_hw_queues = shost->nr_hw_queues ? : 1;
|
||||||
shost->tag_set.queue_depth = shost->can_queue;
|
shost->tag_set.queue_depth = shost->can_queue;
|
||||||
shost->tag_set.cmd_size = cmd_size;
|
shost->tag_set.cmd_size = cmd_size;
|
||||||
shost->tag_set.numa_node = NUMA_NO_NODE;
|
shost->tag_set.numa_node = NUMA_NO_NODE;
|
||||||
|
@ -638,6 +638,14 @@ struct Scsi_Host {
|
|||||||
short unsigned int sg_prot_tablesize;
|
short unsigned int sg_prot_tablesize;
|
||||||
unsigned int max_sectors;
|
unsigned int max_sectors;
|
||||||
unsigned long dma_boundary;
|
unsigned long dma_boundary;
|
||||||
|
/*
|
||||||
|
* In scsi-mq mode, the number of hardware queues supported by the LLD.
|
||||||
|
*
|
||||||
|
* Note: it is assumed that each hardware queue has a queue depth of
|
||||||
|
* can_queue. In other words, the total queue depth per host
|
||||||
|
* is nr_hw_queues * can_queue.
|
||||||
|
*/
|
||||||
|
unsigned nr_hw_queues;
|
||||||
/*
|
/*
|
||||||
* Used to assign serial numbers to the cmds.
|
* Used to assign serial numbers to the cmds.
|
||||||
* Protected by the host lock.
|
* Protected by the host lock.
|
||||||
|
Loading…
Reference in New Issue
Block a user