summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWu Bo <wubo40@huawei.com>2020-03-25 07:53:25 +0100
committerMartin K. Petersen <martin.petersen@oracle.com>2020-03-27 03:48:58 +0100
commit1d99702f903277aeaf17e1873151ba40751ed6ed (patch)
treeb7602fc64666f509dad556bd5e5b0058a3bcc11c
parentscsi: hpsa: correct race condition in offload enabled (diff)
downloadlinux-1d99702f903277aeaf17e1873151ba40751ed6ed.tar.xz
linux-1d99702f903277aeaf17e1873151ba40751ed6ed.zip
scsi: libiscsi: Fix error count for active session
Fix an error count for active session if the total_cmds is invalid on the function iscsi_session_setup(). Decrement the number of active sessions before the funcion return. Link: https://lore.kernel.org/r/EDBAAA0BBBA2AC4E9C8B6B81DEEE1D6916A28542@DGGEML525-MBS.china.huawei.com Reviewed-by: Lee Duncan <lduncan@suuse.com> Signed-off-by: Wu Bo <wubo40@huawei.com> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
-rw-r--r--drivers/scsi/libiscsi.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/scsi/libiscsi.c b/drivers/scsi/libiscsi.c
index ca488c57ead4..874dd4beed10 100644
--- a/drivers/scsi/libiscsi.c
+++ b/drivers/scsi/libiscsi.c
@@ -2771,7 +2771,7 @@ iscsi_session_setup(struct iscsi_transport *iscsit, struct Scsi_Host *shost,
"must be a power of 2.\n", total_cmds);
total_cmds = rounddown_pow_of_two(total_cmds);
if (total_cmds < ISCSI_TOTAL_CMDS_MIN)
- return NULL;
+ goto dec_session_count;
printk(KERN_INFO "iscsi: Rounding can_queue to %d.\n",
total_cmds);
}