[PATCH 4/8] [Target_Core_Mod]: Add transport_free_session()

From: Nicholas A. Bellinger
Date: Sat Dec 20 2008 - 18:02:22 EST


>From a4600727191e4b31ad76f8958359b3713cbc26a7 Mon Sep 17 00:00:00 2001
From: Nicholas Bellinger <nab@xxxxxxxxxxxxxxx>
Date: Sat, 20 Dec 2008 02:53:14 -0800
Subject: [PATCH 4/8] [Target_Core_Mod]: Add transport_free_session()

This patch adds transport_free_session(), which is simply a wrapper
around kmem_cache_free() for se_session_t. It also adds EXPORT_SYMBOL()
usage for $FABRIC_MODs.

Also in transport_deregister_session(), added transport_free_session() usage,
including a conditional to check for the existance of se_session_t->se_portal_group_t.

Signed-off-by: Nicholas A. Bellinger <nab@xxxxxxxxxxxxxxx>
---
drivers/lio-core/target_core_transport.c | 15 ++++++++++++++-
drivers/lio-core/target_core_transport.h | 1 +
2 files changed, 15 insertions(+), 1 deletions(-)

diff --git a/drivers/lio-core/target_core_transport.c b/drivers/lio-core/target_core_transport.c
index 31a96ec..2290f45 100644
--- a/drivers/lio-core/target_core_transport.c
+++ b/drivers/lio-core/target_core_transport.c
@@ -654,11 +654,24 @@ extern void transport_deregister_session_configfs (se_session_t *se_sess)

EXPORT_SYMBOL(transport_deregister_session_configfs);

+extern void transport_free_session (se_session_t *se_sess)
+{
+ kmem_cache_free(se_sess_cache, se_sess);
+ return;
+}
+
+EXPORT_SYMBOL(transport_free_session);
+
extern void transport_deregister_session (se_session_t *se_sess)
{
se_portal_group_t *se_tpg = se_sess->se_tpg;
se_node_acl_t *se_nacl;

+ if (!(se_tpg)) {
+ transport_free_session(se_sess);
+ return;
+ }
+
spin_lock_bh(&se_tpg->session_lock);
list_del(&se_sess->sess_list);
se_sess->se_tpg = NULL;
@@ -685,7 +698,7 @@ extern void transport_deregister_session (se_session_t *se_sess)
spin_unlock_bh(&se_tpg->acl_node_lock);
}

- kmem_cache_free(se_sess_cache, se_sess);
+ transport_free_session(se_sess);

printk("TARGET_CORE[%s]: Deregistered fabric_sess\n",
TPG_TFO(se_tpg)->get_fabric_name());
diff --git a/drivers/lio-core/target_core_transport.h b/drivers/lio-core/target_core_transport.h
index a6a68af..b9fd482 100644
--- a/drivers/lio-core/target_core_transport.h
+++ b/drivers/lio-core/target_core_transport.h
@@ -113,6 +113,7 @@ extern void transport_check_dev_params_delim (char *, char **);
extern struct se_session_s *transport_init_session (void);
extern void __transport_register_session (struct se_portal_group_s *, struct se_node_acl_s *, struct se_session_s *, void *);
extern void transport_register_session (struct se_portal_group_s *, struct se_node_acl_s *, struct se_session_s *, void *);
+extern void transport_free_session (struct se_session_s *);
extern void transport_deregister_session_configfs (struct se_session_s *);
extern void transport_deregister_session (struct se_session_s *);
extern void transport_task_dev_remove_state (struct se_task_s *, struct se_device_s *);
--
1.5.4.1



--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/