iscsi-target: Convert to use target_put_session + sess_kref
authorNicholas Bellinger <nab@linux-iscsi.org>
Mon, 27 Feb 2012 09:43:32 +0000 (01:43 -0800)
committerNicholas Bellinger <nab@linux-iscsi.org>
Sat, 10 Mar 2012 22:42:25 +0000 (14:42 -0800)
This patch converts iscsi-target session code to use se_sess->sess_kref
counting for iscsi session shutdown.  The following cases include:

*) last iscsit_close_connection() shutdown path to invoke close session
*) iscsit_logout_post_handler_closesession() for explict logout
*) iscsit_free_session() caller for explict shutdown

It also moves iscsit_stop_session() call from lio_tpg_close_session()
into lio_tpg_shutdown_session() TFO callbacks to invoke an explict
shutdown, and also changes iscsi_check_for_session_reinstatement()
login code to use se_sess->sess_kref.

(v2: Make iscsit_handle_time2retain_timeout() use target_put_session)

Cc: Andy Grover <agrover@redhat.com>
Cc: Christoph Hellwig <hch@lst.de>
Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
drivers/target/iscsi/iscsi_target.c
drivers/target/iscsi/iscsi_target_configfs.c
drivers/target/iscsi/iscsi_target_erl0.c
drivers/target/iscsi/iscsi_target_login.c

index c3ef2f6f374003afc518d8b2d0b3a4e16adfb5c5..d3b54ecbfcda396459e15ff156eb6b8b1e2504db 100644 (file)
@@ -4168,7 +4168,7 @@ int iscsit_close_connection(
        if (!atomic_read(&sess->session_reinstatement) &&
             atomic_read(&sess->session_fall_back_to_erl0)) {
                spin_unlock_bh(&sess->conn_lock);
-               iscsit_close_session(sess);
+               target_put_session(sess->se_sess);
 
                return 0;
        } else if (atomic_read(&sess->session_logout)) {
@@ -4289,7 +4289,7 @@ static void iscsit_logout_post_handler_closesession(
        iscsit_dec_conn_usage_count(conn);
        iscsit_stop_session(sess, 1, 1);
        iscsit_dec_session_usage_count(sess);
-       iscsit_close_session(sess);
+       target_put_session(sess->se_sess);
 }
 
 static void iscsit_logout_post_handler_samecid(
@@ -4455,7 +4455,7 @@ int iscsit_free_session(struct iscsi_session *sess)
        } else
                spin_unlock_bh(&sess->conn_lock);
 
-       iscsit_close_session(sess);
+       target_put_session(sess->se_sess);
        return 0;
 }
 
index dcef63bf5f9da13eef0d82891c69d86b76a5ecde..1174f74f4fbcf51dd6d73001aaf3351784518062 100644 (file)
@@ -1698,8 +1698,8 @@ static int lio_tpg_shutdown_session(struct se_session *se_sess)
        atomic_set(&sess->session_reinstatement, 1);
        spin_unlock(&sess->conn_lock);
 
-       iscsit_inc_session_usage_count(sess);
        iscsit_stop_time2retain_timer(sess);
+       iscsit_stop_session(sess, 1, 1);
 
        return 1;
 }
@@ -1715,8 +1715,6 @@ static void lio_tpg_close_session(struct se_session *se_sess)
         * If the iSCSI Session for the iSCSI Initiator Node exists,
         * forcefully shutdown the iSCSI NEXUS.
         */
-       iscsit_stop_session(sess, 1, 1);
-       iscsit_dec_session_usage_count(sess);
        iscsit_close_session(sess);
 }
 
index 478451167b62b4c1b3b443e08b1bb6c06ff10cad..1ab0560b09245b6d2e175f0cb72c37dfea6516ea 100644 (file)
@@ -783,7 +783,7 @@ static void iscsit_handle_time2retain_timeout(unsigned long data)
        }
 
        spin_unlock_bh(&se_tpg->session_lock);
-       iscsit_close_session(sess);
+       target_put_session(sess->se_sess);
 }
 
 extern void iscsit_start_time2retain_handler(struct iscsi_session *sess)
index 38cb7ce8469ed36084eb739bd7336f4376f03cbd..18cffff9b45662b190428301029344f62d71996e 100644 (file)
@@ -180,14 +180,16 @@ int iscsi_check_for_session_reinstatement(struct iscsi_conn *conn)
        if (sess->session_state == TARG_SESS_STATE_FAILED) {
                spin_unlock_bh(&sess->conn_lock);
                iscsit_dec_session_usage_count(sess);
-               return iscsit_close_session(sess);
+               target_put_session(sess->se_sess);
+               return 0;
        }
        spin_unlock_bh(&sess->conn_lock);
 
        iscsit_stop_session(sess, 1, 1);
        iscsit_dec_session_usage_count(sess);
 
-       return iscsit_close_session(sess);
+       target_put_session(sess->se_sess);
+       return 0;
 }
 
 static void iscsi_login_set_conn_values(