aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/linux/sunrpc/clnt.h2
-rw-r--r--net/sunrpc/rpcb_clnt.c2
-rw-r--r--net/sunrpc/svc.c35
3 files changed, 38 insertions, 1 deletions
diff --git a/include/linux/sunrpc/clnt.h b/include/linux/sunrpc/clnt.h
index d926fd1a5313..ad09bed239fc 100644
--- a/include/linux/sunrpc/clnt.h
+++ b/include/linux/sunrpc/clnt.h
@@ -136,6 +136,8 @@ void rpc_shutdown_client(struct rpc_clnt *);
136void rpc_release_client(struct rpc_clnt *); 136void rpc_release_client(struct rpc_clnt *);
137void rpc_task_release_client(struct rpc_task *); 137void rpc_task_release_client(struct rpc_task *);
138 138
139int rpcb_create_local(void);
140void rpcb_put_local(void);
139int rpcb_register(u32, u32, int, unsigned short); 141int rpcb_register(u32, u32, int, unsigned short);
140int rpcb_v4_register(const u32 program, const u32 version, 142int rpcb_v4_register(const u32 program, const u32 version,
141 const struct sockaddr *address, 143 const struct sockaddr *address,
diff --git a/net/sunrpc/rpcb_clnt.c b/net/sunrpc/rpcb_clnt.c
index f5309aba1a14..c24626537a7d 100644
--- a/net/sunrpc/rpcb_clnt.c
+++ b/net/sunrpc/rpcb_clnt.c
@@ -320,7 +320,7 @@ out:
320 * Returns zero on success, otherwise a negative errno value 320 * Returns zero on success, otherwise a negative errno value
321 * is returned. 321 * is returned.
322 */ 322 */
323static int rpcb_create_local(void) 323int rpcb_create_local(void)
324{ 324{
325 static DEFINE_MUTEX(rpcb_create_local_mutex); 325 static DEFINE_MUTEX(rpcb_create_local_mutex);
326 int result = 0; 326 int result = 0;
diff --git a/net/sunrpc/svc.c b/net/sunrpc/svc.c
index 6a69a1131fb7..d2d61bfa3306 100644
--- a/net/sunrpc/svc.c
+++ b/net/sunrpc/svc.c
@@ -354,6 +354,41 @@ svc_pool_for_cpu(struct svc_serv *serv, int cpu)
354 return &serv->sv_pools[pidx % serv->sv_nrpools]; 354 return &serv->sv_pools[pidx % serv->sv_nrpools];
355} 355}
356 356
357static int svc_rpcb_setup(struct svc_serv *serv)
358{
359 int err;
360
361 err = rpcb_create_local();
362 if (err)
363 return err;
364
365 /* Remove any stale portmap registrations */
366 svc_unregister(serv);
367 return 0;
368}
369
370static void svc_rpcb_cleanup(struct svc_serv *serv)
371{
372 svc_unregister(serv);
373 rpcb_put_local();
374}
375
376static int svc_uses_rpcbind(struct svc_serv *serv)
377{
378 struct svc_program *progp;
379 unsigned int i;
380
381 for (progp = serv->sv_program; progp; progp = progp->pg_next) {
382 for (i = 0; i < progp->pg_nvers; i++) {
383 if (progp->pg_vers[i] == NULL)
384 continue;
385 if (progp->pg_vers[i]->vs_hidden == 0)
386 return 1;
387 }
388 }
389
390 return 0;
391}
357 392
358/* 393/*
359 * Create an RPC service 394 * Create an RPC service