Commit 5759ff11 authored by Don Brace's avatar Don Brace Committed by Martin K. Petersen

scsi: hpsa: Correct ctrl queue depth

Need to set queue depth for controller devices.

Link: https://lore.kernel.org/r/159562590819.17915.12766718094041027754.stgit@brunhilda
Fixes: 30bda784 ("scsi: hpsa: Increase controller error handling timeout")
Reviewed-by: default avatarScott Teel <scott.teel@microsemi.com>
Signed-off-by: default avatarDon Brace <don.brace@microsemi.com>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent 59526d7a
...@@ -2145,20 +2145,21 @@ static int hpsa_slave_configure(struct scsi_device *sdev) ...@@ -2145,20 +2145,21 @@ static int hpsa_slave_configure(struct scsi_device *sdev)
if (sd) { if (sd) {
sd->was_removed = 0; sd->was_removed = 0;
queue_depth = sd->queue_depth != 0 ?
sd->queue_depth : sdev->host->can_queue;
if (sd->external) { if (sd->external) {
queue_depth = EXTERNAL_QD; queue_depth = EXTERNAL_QD;
sdev->eh_timeout = HPSA_EH_PTRAID_TIMEOUT; sdev->eh_timeout = HPSA_EH_PTRAID_TIMEOUT;
blk_queue_rq_timeout(sdev->request_queue, blk_queue_rq_timeout(sdev->request_queue,
HPSA_EH_PTRAID_TIMEOUT); HPSA_EH_PTRAID_TIMEOUT);
} else if (is_hba_lunid(sd->scsi3addr)) { }
if (is_hba_lunid(sd->scsi3addr)) {
sdev->eh_timeout = CTLR_TIMEOUT; sdev->eh_timeout = CTLR_TIMEOUT;
blk_queue_rq_timeout(sdev->request_queue, CTLR_TIMEOUT); blk_queue_rq_timeout(sdev->request_queue, CTLR_TIMEOUT);
} else {
queue_depth = sd->queue_depth != 0 ?
sd->queue_depth : sdev->host->can_queue;
} }
} else } else {
queue_depth = sdev->host->can_queue; queue_depth = sdev->host->can_queue;
}
scsi_change_queue_depth(sdev, queue_depth); scsi_change_queue_depth(sdev, queue_depth);
......
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