PM / sleep: Asynchronous threads for suspend_noirq
[linux/fpc-iii.git] / drivers / target / iscsi / iscsi_target_transport.c
blob882728fac30c4e8a8fcf9db5e26f826ec86d2f0d
1 #include <linux/spinlock.h>
2 #include <linux/list.h>
3 #include <target/iscsi/iscsi_transport.h>
5 static LIST_HEAD(g_transport_list);
6 static DEFINE_MUTEX(transport_mutex);
8 struct iscsit_transport *iscsit_get_transport(int type)
10 struct iscsit_transport *t;
12 mutex_lock(&transport_mutex);
13 list_for_each_entry(t, &g_transport_list, t_node) {
14 if (t->transport_type == type) {
15 if (t->owner && !try_module_get(t->owner)) {
16 t = NULL;
18 mutex_unlock(&transport_mutex);
19 return t;
22 mutex_unlock(&transport_mutex);
24 return NULL;
27 void iscsit_put_transport(struct iscsit_transport *t)
29 if (t->owner)
30 module_put(t->owner);
33 int iscsit_register_transport(struct iscsit_transport *t)
35 INIT_LIST_HEAD(&t->t_node);
37 mutex_lock(&transport_mutex);
38 list_add_tail(&t->t_node, &g_transport_list);
39 mutex_unlock(&transport_mutex);
41 pr_debug("Registered iSCSI transport: %s\n", t->name);
43 return 0;
45 EXPORT_SYMBOL(iscsit_register_transport);
47 void iscsit_unregister_transport(struct iscsit_transport *t)
49 mutex_lock(&transport_mutex);
50 list_del(&t->t_node);
51 mutex_unlock(&transport_mutex);
53 pr_debug("Unregistered iSCSI transport: %s\n", t->name);
55 EXPORT_SYMBOL(iscsit_unregister_transport);