]> err.no Git - linux-2.6/blob - net/9p/mod.c
b8ac0635ad8379c26552dd990de55c20e2aa17cd
[linux-2.6] / net / 9p / mod.c
1 /*
2  *  net/9p/9p.c
3  *
4  *  9P entry point
5  *
6  *  Copyright (C) 2007 by Latchesar Ionkov <lucho@ionkov.net>
7  *  Copyright (C) 2004 by Eric Van Hensbergen <ericvh@gmail.com>
8  *  Copyright (C) 2002 by Ron Minnich <rminnich@lanl.gov>
9  *
10  *  This program is free software; you can redistribute it and/or modify
11  *  it under the terms of the GNU General Public License version 2
12  *  as published by the Free Software Foundation.
13  *
14  *  This program is distributed in the hope that it will be useful,
15  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
16  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  *  GNU General Public License for more details.
18  *
19  *  You should have received a copy of the GNU General Public License
20  *  along with this program; if not, write to:
21  *  Free Software Foundation
22  *  51 Franklin Street, Fifth Floor
23  *  Boston, MA  02111-1301  USA
24  *
25  */
26
27 #include <linux/module.h>
28 #include <linux/moduleparam.h>
29 #include <net/9p/9p.h>
30 #include <linux/fs.h>
31 #include <linux/parser.h>
32 #include <net/9p/transport.h>
33 #include <linux/list.h>
34
35 #ifdef CONFIG_NET_9P_DEBUG
36 unsigned int p9_debug_level = 0;        /* feature-rific global debug level  */
37 EXPORT_SYMBOL(p9_debug_level);
38 module_param_named(debug, p9_debug_level, uint, 0);
39 MODULE_PARM_DESC(debug, "9P debugging level");
40 #endif
41
42 extern int p9_mux_global_init(void);
43 extern void p9_mux_global_exit(void);
44 extern int p9_sysctl_register(void);
45 extern void p9_sysctl_unregister(void);
46
47 /*
48  * Dynamic Transport Registration Routines
49  *
50  */
51
52 static LIST_HEAD(v9fs_trans_list);
53 static struct p9_trans_module *v9fs_default_transport;
54
55 /**
56  * v9fs_register_trans - register a new transport with 9p
57  * @m - structure describing the transport module and entry points
58  *
59  */
60 void v9fs_register_trans(struct p9_trans_module *m)
61 {
62         list_add_tail(&m->list, &v9fs_trans_list);
63         if (m->def)
64                 v9fs_default_transport = m;
65 }
66 EXPORT_SYMBOL(v9fs_register_trans);
67
68 /**
69  * v9fs_match_trans - match transport versus registered transports
70  * @arg: string identifying transport
71  *
72  */
73 struct p9_trans_module *v9fs_match_trans(const substring_t *name)
74 {
75         struct list_head *p;
76         struct p9_trans_module *t = NULL;
77
78         list_for_each(p, &v9fs_trans_list) {
79                 t = list_entry(p, struct p9_trans_module, list);
80                 if (strncmp(t->name, name->from, name->to-name->from) == 0)
81                         break;
82         }
83         return t;
84 }
85 EXPORT_SYMBOL(v9fs_match_trans);
86
87 /**
88  * v9fs_default_trans - returns pointer to default transport
89  *
90  */
91
92 struct p9_trans_module *v9fs_default_trans(void)
93 {
94         if (v9fs_default_transport)
95                 return v9fs_default_transport;
96         else if (!list_empty(&v9fs_trans_list))
97                 return list_first_entry(&v9fs_trans_list,
98                                         struct p9_trans_module, list);
99         else
100                 return NULL;
101 }
102 EXPORT_SYMBOL(v9fs_default_trans);
103
104
105 /**
106  * v9fs_init - Initialize module
107  *
108  */
109 static int __init init_p9(void)
110 {
111         int ret;
112
113         p9_error_init();
114         printk(KERN_INFO "Installing 9P2000 support\n");
115         ret = p9_mux_global_init();
116         if (ret) {
117                 printk(KERN_WARNING "9p: starting mux failed\n");
118                 return ret;
119         }
120
121         ret = p9_sysctl_register();
122         if (ret) {
123                 printk(KERN_WARNING "9p: registering sysctl failed\n");
124                 return ret;
125         }
126
127         return ret;
128 }
129
130 /**
131  * v9fs_init - shutdown module
132  *
133  */
134
135 static void __exit exit_p9(void)
136 {
137         p9_sysctl_unregister();
138         p9_mux_global_exit();
139 }
140
141 module_init(init_p9)
142 module_exit(exit_p9)
143
144 MODULE_AUTHOR("Latchesar Ionkov <lucho@ionkov.net>");
145 MODULE_AUTHOR("Eric Van Hensbergen <ericvh@gmail.com>");
146 MODULE_AUTHOR("Ron Minnich <rminnich@lanl.gov>");
147 MODULE_LICENSE("GPL");