4 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License version 2 only,
8 * as published by the Free Software Foundation.
10 * This program is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * General Public License version 2 for more details (a copy is included
14 * in the LICENSE file that accompanied this code).
16 * You should have received a copy of the GNU General Public License
17 * version 2 along with this program; If not, see
18 * http://www.sun.com/software/products/lustre/docs/GPLv2.pdf
20 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
21 * CA 95054 USA or visit www.sun.com if you need additional information or
27 * Copyright (c) 2004, 2010, Oracle and/or its affiliates. All rights reserved.
28 * Use is subject to license terms.
30 * Copyright (c) 2012, 2015, Intel Corporation.
33 * This file is part of Lustre, http://www.lustre.org/
34 * Lustre is a trademark of Sun Microsystems, Inc.
37 #define DEBUG_SUBSYSTEM S_LNET
38 #include "../../include/linux/lnet/lib-lnet.h"
39 #include "../../include/linux/lnet/lib-dlc.h"
41 static int config_on_load
;
42 module_param(config_on_load
, int, 0444);
43 MODULE_PARM_DESC(config_on_load
, "configure network at module load");
45 static struct mutex lnet_config_mutex
;
48 lnet_configure(void *arg
)
50 /* 'arg' only there so I can be passed to cfs_create_thread() */
53 mutex_lock(&lnet_config_mutex
);
55 if (!the_lnet
.ln_niinit_self
) {
56 rc
= LNetNIInit(LUSTRE_SRV_LNET_PID
);
58 the_lnet
.ln_niinit_self
= 1;
63 mutex_unlock(&lnet_config_mutex
);
68 lnet_unconfigure(void)
72 mutex_lock(&lnet_config_mutex
);
74 if (the_lnet
.ln_niinit_self
) {
75 the_lnet
.ln_niinit_self
= 0;
79 mutex_lock(&the_lnet
.ln_api_mutex
);
80 refcount
= the_lnet
.ln_refcount
;
81 mutex_unlock(&the_lnet
.ln_api_mutex
);
83 mutex_unlock(&lnet_config_mutex
);
84 return !refcount
? 0 : -EBUSY
;
88 lnet_dyn_configure(struct libcfs_ioctl_hdr
*hdr
)
90 struct lnet_ioctl_config_data
*conf
=
91 (struct lnet_ioctl_config_data
*)hdr
;
94 if (conf
->cfg_hdr
.ioc_len
< sizeof(*conf
))
97 mutex_lock(&lnet_config_mutex
);
98 if (!the_lnet
.ln_niinit_self
) {
102 rc
= lnet_dyn_add_ni(LUSTRE_SRV_LNET_PID
,
103 conf
->cfg_config_u
.cfg_net
.net_intf
,
104 conf
->cfg_config_u
.cfg_net
.net_peer_timeout
,
105 conf
->cfg_config_u
.cfg_net
.net_peer_tx_credits
,
106 conf
->cfg_config_u
.cfg_net
.net_peer_rtr_credits
,
107 conf
->cfg_config_u
.cfg_net
.net_max_tx_credits
);
109 mutex_unlock(&lnet_config_mutex
);
115 lnet_dyn_unconfigure(struct libcfs_ioctl_hdr
*hdr
)
117 struct lnet_ioctl_config_data
*conf
=
118 (struct lnet_ioctl_config_data
*)hdr
;
121 if (conf
->cfg_hdr
.ioc_len
< sizeof(*conf
))
124 mutex_lock(&lnet_config_mutex
);
125 if (!the_lnet
.ln_niinit_self
) {
129 rc
= lnet_dyn_del_ni(conf
->cfg_net
);
131 mutex_unlock(&lnet_config_mutex
);
137 lnet_ioctl(unsigned int cmd
, struct libcfs_ioctl_hdr
*hdr
)
142 case IOC_LIBCFS_CONFIGURE
: {
143 struct libcfs_ioctl_data
*data
=
144 (struct libcfs_ioctl_data
*)hdr
;
146 if (data
->ioc_hdr
.ioc_len
< sizeof(*data
))
149 the_lnet
.ln_nis_from_mod_params
= data
->ioc_flags
;
150 return lnet_configure(NULL
);
153 case IOC_LIBCFS_UNCONFIGURE
:
154 return lnet_unconfigure();
156 case IOC_LIBCFS_ADD_NET
:
157 return lnet_dyn_configure(hdr
);
159 case IOC_LIBCFS_DEL_NET
:
160 return lnet_dyn_unconfigure(hdr
);
164 * Passing LNET_PID_ANY only gives me a ref if the net is up
165 * already; I'll need it to ensure the net can't go down while
168 rc
= LNetNIInit(LNET_PID_ANY
);
170 rc
= LNetCtl(cmd
, hdr
);
177 static DECLARE_IOCTL_HANDLER(lnet_ioctl_handler
, lnet_ioctl
);
184 mutex_init(&lnet_config_mutex
);
188 CERROR("lnet_init: error %d\n", rc
);
192 rc
= libcfs_register_ioctl(&lnet_ioctl_handler
);
195 if (config_on_load
) {
197 * Have to schedule a separate thread to avoid deadlocking
200 (void) kthread_run(lnet_configure
, NULL
, "lnet_initd");
211 rc
= libcfs_deregister_ioctl(&lnet_ioctl_handler
);
217 MODULE_AUTHOR("OpenSFS, Inc. <http://www.lustre.org/>");
218 MODULE_DESCRIPTION("LNet v3.1");
219 MODULE_LICENSE("GPL");
220 MODULE_VERSION("1.0.0");
222 module_init(init_lnet
);
223 module_exit(fini_lnet
);
This page took 0.047505 seconds and 5 git commands to generate.