LNET_MUTEX_LOCK(&lnet_config_mutex);
if (!the_lnet.ln_niinit_self) {
+ rc = try_module_get(THIS_MODULE);
+
+ if (rc != 1)
+ goto out;
+
rc = LNetNIInit(LNET_PID_LUSTRE);
if (rc >= 0) {
the_lnet.ln_niinit_self = 1;
rc = 0;
+ } else {
+ module_put(THIS_MODULE);
}
}
+out:
LNET_MUTEX_UNLOCK(&lnet_config_mutex);
return rc;
}
static int
lnet_unconfigure (void)
{
- int refcount;
+ int refcount;
+
+ LNET_MUTEX_LOCK(&lnet_config_mutex);
- LNET_MUTEX_LOCK(&lnet_config_mutex);
+ if (the_lnet.ln_niinit_self) {
+ the_lnet.ln_niinit_self = 0;
+ LNetNIFini();
+ module_put(THIS_MODULE);
+ }
- if (the_lnet.ln_niinit_self) {
- the_lnet.ln_niinit_self = 0;
- LNetNIFini();
- }
+ LNET_MUTEX_LOCK(&the_lnet.ln_api_mutex);
+ refcount = the_lnet.ln_refcount;
+ LNET_MUTEX_UNLOCK(&the_lnet.ln_api_mutex);
- LNET_MUTEX_LOCK(&the_lnet.ln_api_mutex);
- refcount = the_lnet.ln_refcount;
- LNET_MUTEX_UNLOCK(&the_lnet.ln_api_mutex);
+ LNET_MUTEX_UNLOCK(&lnet_config_mutex);
- LNET_MUTEX_UNLOCK(&lnet_config_mutex);
- return (refcount == 0) ? 0 : -EBUSY;
+ return (refcount == 0) ? 0 : -EBUSY;
}
static int