From: Nicholas Bellinger Date: Sun, 18 Aug 2013 22:07:44 +0000 (-0700) Subject: iscsi-target: Fix iscsit_transport reference leak during NP thread reset X-Git-Tag: upstream/snapshot3+hdmi~4469^2~2 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=c9a03c12464c851e691e8d5b6c9deba779c512e0;p=platform%2Fadaptation%2Frenesas_rcar%2Frenesas_kernel.git iscsi-target: Fix iscsit_transport reference leak during NP thread reset This patch fixes a bug in __iscsi_target_login_thread() where an explicit network portal thread reset ends up leaking the iscsit_transport module reference, along with the associated iscsi_conn allocation. This manifests itself with iser-target where a NP reset causes the extra iscsit_transport reference to be taken in iscsit_conn_set_transport() during the reset, which prevents the ib_isert module from being unloaded after the NP thread shutdown has finished. Cc: stable@vger.kernel.org # v3.10+ Signed-off-by: Nicholas Bellinger --- diff --git a/drivers/target/iscsi/iscsi_target_login.c b/drivers/target/iscsi/iscsi_target_login.c index 3402241..bc788c5 100644 --- a/drivers/target/iscsi/iscsi_target_login.c +++ b/drivers/target/iscsi/iscsi_target_login.c @@ -1163,12 +1163,11 @@ static int __iscsi_target_login_thread(struct iscsi_np *np) if (np->np_thread_state == ISCSI_NP_THREAD_RESET) { spin_unlock_bh(&np->np_thread_lock); complete(&np->np_restart_comp); - if (ret == -ENODEV) { - iscsit_put_transport(conn->conn_transport); - kfree(conn); - conn = NULL; + iscsit_put_transport(conn->conn_transport); + kfree(conn); + conn = NULL; + if (ret == -ENODEV) goto out; - } /* Get another socket */ return 1; }