aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi/qla2xxx
diff options
context:
space:
mode:
authorMike Christie <michaelc@cs.wisc.edu>2009-10-15 20:46:39 -0400
committerJames Bottomley <James.Bottomley@suse.de>2009-12-04 13:00:41 -0500
commite881a172dac4d9ea3b2a1540041d872963c269bd (patch)
tree9eb1f344b107806c0041c4e0a64192a055117289 /drivers/scsi/qla2xxx
parentdbf9bfe615717d1145f263c0049fe2328e6ed395 (diff)
[SCSI] modify change_queue_depth to take in reason why it is being called
This patch modifies scsi_host_template->change_queue_depth so that it takes an argument indicating why it is being called. This will be used so that if a LLD needs to do some extra processing when handling queue fulls or later ramp ups, it can do so. This is a simple port of the drivers setting a change_queue_depth callback. In the patch I just have these LLDs adjust the queue depth if the user was requesting it. Signed-off-by: Mike Christie <michaelc@cs.wisc.edu> [Vasu.Dev: v2 Also converted pmcraid_change_queue_depth and then verified all modules compile using "make allmodconfig" for any new build warnings on X86_64. Updated original description after combing two original patches from Mike to make this patch git bisectable.] Signed-off-by: Vasu Dev <vasu.dev@intel.com> [jejb: fixed up 53c700] Signed-off-by: James Bottomley <James.Bottomley@suse.de>
Diffstat (limited to 'drivers/scsi/qla2xxx')
-rw-r--r--drivers/scsi/qla2xxx/qla_os.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/drivers/scsi/qla2xxx/qla_os.c b/drivers/scsi/qla2xxx/qla_os.c
index ecf2a40d70be..d69744a62fe4 100644
--- a/drivers/scsi/qla2xxx/qla_os.c
+++ b/drivers/scsi/qla2xxx/qla_os.c
@@ -138,7 +138,7 @@ static int qla2xxx_eh_target_reset(struct scsi_cmnd *);
138static int qla2xxx_eh_bus_reset(struct scsi_cmnd *); 138static int qla2xxx_eh_bus_reset(struct scsi_cmnd *);
139static int qla2xxx_eh_host_reset(struct scsi_cmnd *); 139static int qla2xxx_eh_host_reset(struct scsi_cmnd *);
140 140
141static int qla2x00_change_queue_depth(struct scsi_device *, int); 141static int qla2x00_change_queue_depth(struct scsi_device *, int, int);
142static int qla2x00_change_queue_type(struct scsi_device *, int); 142static int qla2x00_change_queue_type(struct scsi_device *, int);
143 143
144struct scsi_host_template qla2xxx_driver_template = { 144struct scsi_host_template qla2xxx_driver_template = {
@@ -1235,8 +1235,11 @@ qla2xxx_slave_destroy(struct scsi_device *sdev)
1235} 1235}
1236 1236
1237static int 1237static int
1238qla2x00_change_queue_depth(struct scsi_device *sdev, int qdepth) 1238qla2x00_change_queue_depth(struct scsi_device *sdev, int qdepth, int reason)
1239{ 1239{
1240 if (reason != SCSI_QDEPTH_DEFAULT)
1241 return -EOPNOTSUPP;
1242
1240 scsi_adjust_queue_depth(sdev, scsi_get_tag_type(sdev), qdepth); 1243 scsi_adjust_queue_depth(sdev, scsi_get_tag_type(sdev), qdepth);
1241 return sdev->queue_depth; 1244 return sdev->queue_depth;
1242} 1245}