|
@@ -315,7 +315,7 @@ void transport_register_session(
|
|
|
}
|
|
|
EXPORT_SYMBOL(transport_register_session);
|
|
|
|
|
|
-static void target_release_session(struct kref *kref)
|
|
|
+void target_release_session(struct kref *kref)
|
|
|
{
|
|
|
struct se_session *se_sess = container_of(kref,
|
|
|
struct se_session, sess_kref);
|
|
@@ -332,6 +332,12 @@ EXPORT_SYMBOL(target_get_session);
|
|
|
|
|
|
void target_put_session(struct se_session *se_sess)
|
|
|
{
|
|
|
+ struct se_portal_group *tpg = se_sess->se_tpg;
|
|
|
+
|
|
|
+ if (tpg->se_tpg_tfo->put_session != NULL) {
|
|
|
+ tpg->se_tpg_tfo->put_session(se_sess);
|
|
|
+ return;
|
|
|
+ }
|
|
|
kref_put(&se_sess->sess_kref, target_release_session);
|
|
|
}
|
|
|
EXPORT_SYMBOL(target_put_session);
|