Commit 40373b12 authored by Trond Myklebust's avatar Trond Myklebust Committed by J. Bruce Fields

lockd: Pass the user cred from knfsd when starting the lockd server

When starting up a new knfsd server, pass the user cred to the
supporting lockd server.
Signed-off-by: default avatarTrond Myklebust <trond.myklebust@hammerspace.com>
Signed-off-by: default avatarJ. Bruce Fields <bfields@redhat.com>
parent 1237d354
...@@ -56,7 +56,7 @@ struct nlm_host *nlmclnt_init(const struct nlmclnt_initdata *nlm_init) ...@@ -56,7 +56,7 @@ struct nlm_host *nlmclnt_init(const struct nlmclnt_initdata *nlm_init)
u32 nlm_version = (nlm_init->nfs_version == 2) ? 1 : 4; u32 nlm_version = (nlm_init->nfs_version == 2) ? 1 : 4;
int status; int status;
status = lockd_up(nlm_init->net); status = lockd_up(nlm_init->net, nlm_init->cred);
if (status < 0) if (status < 0)
return ERR_PTR(status); return ERR_PTR(status);
...@@ -241,7 +241,7 @@ reclaimer(void *ptr) ...@@ -241,7 +241,7 @@ reclaimer(void *ptr)
allow_signal(SIGKILL); allow_signal(SIGKILL);
down_write(&host->h_rwsem); down_write(&host->h_rwsem);
lockd_up(net); /* note: this cannot fail as lockd is already running */ lockd_up(net, NULL); /* note: this cannot fail as lockd is already running */
dprintk("lockd: reclaiming locks for host %s\n", host->h_name); dprintk("lockd: reclaiming locks for host %s\n", host->h_name);
......
...@@ -188,9 +188,9 @@ lockd(void *vrqstp) ...@@ -188,9 +188,9 @@ lockd(void *vrqstp)
static int create_lockd_listener(struct svc_serv *serv, const char *name, static int create_lockd_listener(struct svc_serv *serv, const char *name,
struct net *net, const int family, struct net *net, const int family,
const unsigned short port) const unsigned short port,
const struct cred *cred)
{ {
const struct cred *cred = current_cred();
struct svc_xprt *xprt; struct svc_xprt *xprt;
xprt = svc_find_xprt(serv, name, net, family, 0); xprt = svc_find_xprt(serv, name, net, family, 0);
...@@ -202,15 +202,17 @@ static int create_lockd_listener(struct svc_serv *serv, const char *name, ...@@ -202,15 +202,17 @@ static int create_lockd_listener(struct svc_serv *serv, const char *name,
} }
static int create_lockd_family(struct svc_serv *serv, struct net *net, static int create_lockd_family(struct svc_serv *serv, struct net *net,
const int family) const int family, const struct cred *cred)
{ {
int err; int err;
err = create_lockd_listener(serv, "udp", net, family, nlm_udpport); err = create_lockd_listener(serv, "udp", net, family, nlm_udpport,
cred);
if (err < 0) if (err < 0)
return err; return err;
return create_lockd_listener(serv, "tcp", net, family, nlm_tcpport); return create_lockd_listener(serv, "tcp", net, family, nlm_tcpport,
cred);
} }
/* /*
...@@ -223,16 +225,17 @@ static int create_lockd_family(struct svc_serv *serv, struct net *net, ...@@ -223,16 +225,17 @@ static int create_lockd_family(struct svc_serv *serv, struct net *net,
* Returns zero if all listeners are available; otherwise a * Returns zero if all listeners are available; otherwise a
* negative errno value is returned. * negative errno value is returned.
*/ */
static int make_socks(struct svc_serv *serv, struct net *net) static int make_socks(struct svc_serv *serv, struct net *net,
const struct cred *cred)
{ {
static int warned; static int warned;
int err; int err;
err = create_lockd_family(serv, net, PF_INET); err = create_lockd_family(serv, net, PF_INET, cred);
if (err < 0) if (err < 0)
goto out_err; goto out_err;
err = create_lockd_family(serv, net, PF_INET6); err = create_lockd_family(serv, net, PF_INET6, cred);
if (err < 0 && err != -EAFNOSUPPORT) if (err < 0 && err != -EAFNOSUPPORT)
goto out_err; goto out_err;
...@@ -247,7 +250,8 @@ static int make_socks(struct svc_serv *serv, struct net *net) ...@@ -247,7 +250,8 @@ static int make_socks(struct svc_serv *serv, struct net *net)
return err; return err;
} }
static int lockd_up_net(struct svc_serv *serv, struct net *net) static int lockd_up_net(struct svc_serv *serv, struct net *net,
const struct cred *cred)
{ {
struct lockd_net *ln = net_generic(net, lockd_net_id); struct lockd_net *ln = net_generic(net, lockd_net_id);
int error; int error;
...@@ -259,7 +263,7 @@ static int lockd_up_net(struct svc_serv *serv, struct net *net) ...@@ -259,7 +263,7 @@ static int lockd_up_net(struct svc_serv *serv, struct net *net)
if (error) if (error)
goto err_bind; goto err_bind;
error = make_socks(serv, net); error = make_socks(serv, net, cred);
if (error < 0) if (error < 0)
goto err_bind; goto err_bind;
set_grace_period(net); set_grace_period(net);
...@@ -462,7 +466,7 @@ static struct svc_serv *lockd_create_svc(void) ...@@ -462,7 +466,7 @@ static struct svc_serv *lockd_create_svc(void)
/* /*
* Bring up the lockd process if it's not already up. * Bring up the lockd process if it's not already up.
*/ */
int lockd_up(struct net *net) int lockd_up(struct net *net, const struct cred *cred)
{ {
struct svc_serv *serv; struct svc_serv *serv;
int error; int error;
...@@ -475,7 +479,7 @@ int lockd_up(struct net *net) ...@@ -475,7 +479,7 @@ int lockd_up(struct net *net)
goto err_create; goto err_create;
} }
error = lockd_up_net(serv, net); error = lockd_up_net(serv, net, cred);
if (error < 0) { if (error < 0) {
lockd_unregister_notifiers(); lockd_unregister_notifiers();
goto err_put; goto err_put;
......
...@@ -552,6 +552,7 @@ static int nfs_start_lockd(struct nfs_server *server) ...@@ -552,6 +552,7 @@ static int nfs_start_lockd(struct nfs_server *server)
1 : 0, 1 : 0,
.net = clp->cl_net, .net = clp->cl_net,
.nlmclnt_ops = clp->cl_nfs_mod->rpc_ops->nlmclnt_ops, .nlmclnt_ops = clp->cl_nfs_mod->rpc_ops->nlmclnt_ops,
.cred = current_cred(),
}; };
if (nlm_init.nfs_version > 3) if (nlm_init.nfs_version > 3)
......
...@@ -364,7 +364,7 @@ static int nfsd_startup_net(int nrservs, struct net *net, const struct cred *cre ...@@ -364,7 +364,7 @@ static int nfsd_startup_net(int nrservs, struct net *net, const struct cred *cre
goto out_socks; goto out_socks;
if (nfsd_needs_lockd(nn) && !nn->lockd_up) { if (nfsd_needs_lockd(nn) && !nn->lockd_up) {
ret = lockd_up(net); ret = lockd_up(net, cred);
if (ret) if (ret)
goto out_socks; goto out_socks;
nn->lockd_up = 1; nn->lockd_up = 1;
......
...@@ -46,6 +46,7 @@ struct nlmclnt_initdata { ...@@ -46,6 +46,7 @@ struct nlmclnt_initdata {
int noresvport; int noresvport;
struct net *net; struct net *net;
const struct nlmclnt_operations *nlmclnt_ops; const struct nlmclnt_operations *nlmclnt_ops;
const struct cred *cred;
}; };
/* /*
...@@ -75,7 +76,7 @@ struct nlmclnt_operations { ...@@ -75,7 +76,7 @@ struct nlmclnt_operations {
}; };
extern int nlmclnt_proc(struct nlm_host *host, int cmd, struct file_lock *fl, void *data); extern int nlmclnt_proc(struct nlm_host *host, int cmd, struct file_lock *fl, void *data);
extern int lockd_up(struct net *net); extern int lockd_up(struct net *net, const struct cred *cred);
extern void lockd_down(struct net *net); extern void lockd_down(struct net *net);
#endif /* LINUX_LOCKD_BIND_H */ #endif /* LINUX_LOCKD_BIND_H */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment