提交 24452239 编写于 作者: S Stanislav Kinsbursky 提交者: J. Bruce Fields

LockD: service creation function introduced

This function creates service if it doesn't exist, or increases usage
counter if it does, and returns a pointer to it.  The usage counter will
be droppepd by svc_destroy() later in lockd_up().
Signed-off-by: NStanislav Kinsbursky <skinsbursky@parallels.com>
Signed-off-by: NJ. Bruce Fields <bfields@redhat.com>
上级 dbf9b5d7
...@@ -291,21 +291,20 @@ static void lockd_down_net(struct svc_serv *serv, struct net *net) ...@@ -291,21 +291,20 @@ static void lockd_down_net(struct svc_serv *serv, struct net *net)
} }
} }
/* static struct svc_serv *lockd_create_svc(void)
* Bring up the lockd process if it's not already up.
*/
int lockd_up(struct net *net)
{ {
struct svc_serv *serv; struct svc_serv *serv;
int error = 0;
mutex_lock(&nlmsvc_mutex);
/* /*
* Check whether we're already up and running. * Check whether we're already up and running.
*/ */
if (nlmsvc_rqst) { if (nlmsvc_rqst) {
error = lockd_up_net(nlmsvc_rqst->rq_server, net); /*
goto out; * Note: increase service usage, because later in case of error
* svc_destroy() will be called.
*/
svc_get(nlmsvc_rqst->rq_server);
return nlmsvc_rqst->rq_server;
} }
/* /*
...@@ -316,11 +315,28 @@ int lockd_up(struct net *net) ...@@ -316,11 +315,28 @@ int lockd_up(struct net *net)
printk(KERN_WARNING printk(KERN_WARNING
"lockd_up: no pid, %d users??\n", nlmsvc_users); "lockd_up: no pid, %d users??\n", nlmsvc_users);
error = -ENOMEM;
serv = svc_create(&nlmsvc_program, LOCKD_BUFSIZE, NULL); serv = svc_create(&nlmsvc_program, LOCKD_BUFSIZE, NULL);
if (!serv) { if (!serv) {
printk(KERN_WARNING "lockd_up: create service failed\n"); printk(KERN_WARNING "lockd_up: create service failed\n");
goto out; return ERR_PTR(-ENOMEM);
}
return serv;
}
/*
* Bring up the lockd process if it's not already up.
*/
int lockd_up(struct net *net)
{
struct svc_serv *serv;
int error = 0;
mutex_lock(&nlmsvc_mutex);
serv = lockd_create_svc();
if (IS_ERR(serv)) {
error = PTR_ERR(serv);
goto err_create;
} }
error = lockd_up_net(serv, net); error = lockd_up_net(serv, net);
...@@ -360,9 +376,9 @@ int lockd_up(struct net *net) ...@@ -360,9 +376,9 @@ int lockd_up(struct net *net)
*/ */
err_net: err_net:
svc_destroy(serv); svc_destroy(serv);
out:
if (!error) if (!error)
nlmsvc_users++; nlmsvc_users++;
err_create:
mutex_unlock(&nlmsvc_mutex); mutex_unlock(&nlmsvc_mutex);
return error; return error;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册