[SCSI] libiscsi, iscsi_tcp, ib_iser: fix setting of can_queue with old tools.
This patch fixes two bugs that are related. 1. Old tools did not set can_queue/cmds_max. This patch modifies libiscsi so that when we add the host we catch this and set it to the default. 2. iscsi_tcp thought that the scsi command that was passed to the eh functions needed a iscsi_cmd_task allocated for it. It only needed a mgmt task, and now it does not matter since it all comes from the same pool and libiscsi handles this for the drivers. ib_iser had copied iscsi_tcp's code and set can_queue to its max - 1 to handle this. So this patch removes the max -1, and just sets it to the max. Signed-off-by: Mike Christie <michaelc@cs.wisc.edu> Signed-off-by: James Bottomley <James.Bottomley@HansenPartnership.com>
This commit is contained in:

committed by
James Bottomley

parent
c95fddc729
commit
8e9a20cee4
@@ -1857,6 +1857,9 @@ EXPORT_SYMBOL_GPL(iscsi_pool_free);
|
||||
*/
|
||||
int iscsi_host_add(struct Scsi_Host *shost, struct device *pdev)
|
||||
{
|
||||
if (!shost->can_queue)
|
||||
shost->can_queue = ISCSI_DEF_XMIT_CMDS_MAX;
|
||||
|
||||
return scsi_add_host(shost, pdev);
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(iscsi_host_add);
|
||||
@@ -1942,6 +1945,9 @@ iscsi_session_setup(struct iscsi_transport *iscsit, struct Scsi_Host *shost,
|
||||
struct iscsi_session *session;
|
||||
struct iscsi_cls_session *cls_session;
|
||||
int cmd_i, scsi_cmds, total_cmds = cmds_max;
|
||||
|
||||
if (!total_cmds)
|
||||
total_cmds = ISCSI_DEF_XMIT_CMDS_MAX;
|
||||
/*
|
||||
* The iscsi layer needs some tasks for nop handling and tmfs,
|
||||
* so the cmds_max must at least be greater than ISCSI_MGMT_CMDS_MAX
|
||||
|
Reference in New Issue
Block a user