Commit 626bac73 authored by Maurizio Lombardi's avatar Maurizio Lombardi Committed by Martin K. Petersen
Browse files

scsi: target: iscsi: calling iscsit_stop_session() inside iscsit_close_session() has no effect

iscsit_close_session() can only be called when nconn is zero (otherwise a
kernel panic is triggered). If nconn is zero then iscsit_stop_session()
does nothing and exits, so calling it makes no sense.

We still need to call iscsit_check_session_usage_count() because this
function will sleep if the session's refcount is not zero and we don't want
to destroy the session structure if it's still being referenced.

Link: https://lore.kernel.org/r/20200313170656.9716-4-mlombard@redhat.com


Tested-by: default avatarRahul Kundu <rahul.kundu@chelsio.com>
Signed-off-by: default avatarMaurizio Lombardi <mlombard@redhat.com>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent 57c46e9f
Loading
Loading
Loading
Loading
+1 −2
Original line number Original line Diff line number Diff line
@@ -4381,8 +4381,7 @@ int iscsit_close_session(struct iscsi_session *sess)
	 * restart the timer and exit.
	 * restart the timer and exit.
	 */
	 */
	if (!in_interrupt()) {
	if (!in_interrupt()) {
		if (iscsit_check_session_usage_count(sess) == 1)
		iscsit_check_session_usage_count(sess);
			iscsit_stop_session(sess, 1, 1);
	} else {
	} else {
		if (iscsit_check_session_usage_count(sess) == 2) {
		if (iscsit_check_session_usage_count(sess) == 2) {
			atomic_set(&sess->session_logout, 0);
			atomic_set(&sess->session_logout, 0);