aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVasu Dev <vasu.dev@intel.com>2009-10-15 20:46:55 -0400
committerJames Bottomley <James.Bottomley@suse.de>2009-12-04 13:00:43 -0500
commit14caf44c69184ed72d46a2f883311daf27a4192f (patch)
treecdfdf95ea884116de6595cc8d89482b89ba8ccaa
parent5c20848a096fb1880ded99816be79d78ca1cd696 (diff)
[SCSI] fcoe, libfc: fix an libfc issue with queue ramp down in libfc
The cmd_per_lun value is used by scsi-ml as fall back lowest queue_depth value but in case of libfc cmd_per_lun is set to same value as max queue_depth = 32. So this patch reduces cmd_per_lun value to 3 and configures each lun with default max queue_depth 32 in fc_slave_alloc. Signed-off-by: Vasu Dev <vasu.dev@intel.com> Acked-by: Robert Love <robert.w.love@intel.com> Signed-off-by: James Bottomley <James.Bottomley@suse.de>
-rw-r--r--drivers/scsi/fcoe/fcoe.c2
-rw-r--r--drivers/scsi/libfc/fc_fcp.c14
2 files changed, 7 insertions, 9 deletions
diff --git a/drivers/scsi/fcoe/fcoe.c b/drivers/scsi/fcoe/fcoe.c
index aef29afb6e71..4efbc17a7d7f 100644
--- a/drivers/scsi/fcoe/fcoe.c
+++ b/drivers/scsi/fcoe/fcoe.c
@@ -137,7 +137,7 @@ static struct scsi_host_template fcoe_shost_template = {
137 .change_queue_depth = fc_change_queue_depth, 137 .change_queue_depth = fc_change_queue_depth,
138 .change_queue_type = fc_change_queue_type, 138 .change_queue_type = fc_change_queue_type,
139 .this_id = -1, 139 .this_id = -1,
140 .cmd_per_lun = 32, 140 .cmd_per_lun = 3,
141 .can_queue = FCOE_MAX_OUTSTANDING_COMMANDS, 141 .can_queue = FCOE_MAX_OUTSTANDING_COMMANDS,
142 .use_clustering = ENABLE_CLUSTERING, 142 .use_clustering = ENABLE_CLUSTERING,
143 .sg_tablesize = SG_ALL, 143 .sg_tablesize = SG_ALL,
diff --git a/drivers/scsi/libfc/fc_fcp.c b/drivers/scsi/libfc/fc_fcp.c
index c0dc8e151c65..48de805eb193 100644
--- a/drivers/scsi/libfc/fc_fcp.c
+++ b/drivers/scsi/libfc/fc_fcp.c
@@ -2033,18 +2033,16 @@ EXPORT_SYMBOL(fc_eh_host_reset);
2033int fc_slave_alloc(struct scsi_device *sdev) 2033int fc_slave_alloc(struct scsi_device *sdev)
2034{ 2034{
2035 struct fc_rport *rport = starget_to_rport(scsi_target(sdev)); 2035 struct fc_rport *rport = starget_to_rport(scsi_target(sdev));
2036 int queue_depth;
2037 2036
2038 if (!rport || fc_remote_port_chkready(rport)) 2037 if (!rport || fc_remote_port_chkready(rport))
2039 return -ENXIO; 2038 return -ENXIO;
2040 2039
2041 if (sdev->tagged_supported) { 2040 if (sdev->tagged_supported)
2042 if (sdev->host->hostt->cmd_per_lun) 2041 scsi_activate_tcq(sdev, FC_FCP_DFLT_QUEUE_DEPTH);
2043 queue_depth = sdev->host->hostt->cmd_per_lun; 2042 else
2044 else 2043 scsi_adjust_queue_depth(sdev, scsi_get_tag_type(sdev),
2045 queue_depth = FC_FCP_DFLT_QUEUE_DEPTH; 2044 FC_FCP_DFLT_QUEUE_DEPTH);
2046 scsi_activate_tcq(sdev, queue_depth); 2045
2047 }
2048 return 0; 2046 return 0;
2049} 2047}
2050EXPORT_SYMBOL(fc_slave_alloc); 2048EXPORT_SYMBOL(fc_slave_alloc);