| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * linux/net/sunrpc/sunrpc_syms.c | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Symbols exported by the sunrpc module. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (C) 1997 Olaf Kirch <okir@monad.swb.de> | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <linux/module.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <linux/types.h>
 | 
					
						
							|  |  |  | #include <linux/uio.h>
 | 
					
						
							|  |  |  | #include <linux/unistd.h>
 | 
					
						
							|  |  |  | #include <linux/init.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <linux/sunrpc/sched.h>
 | 
					
						
							|  |  |  | #include <linux/sunrpc/clnt.h>
 | 
					
						
							|  |  |  | #include <linux/sunrpc/svc.h>
 | 
					
						
							|  |  |  | #include <linux/sunrpc/svcsock.h>
 | 
					
						
							|  |  |  | #include <linux/sunrpc/auth.h>
 | 
					
						
							|  |  |  | #include <linux/workqueue.h>
 | 
					
						
							|  |  |  | #include <linux/sunrpc/rpc_pipe_fs.h>
 | 
					
						
							| 
									
										
										
										
											2007-09-10 13:47:31 -04:00
										 |  |  | #include <linux/sunrpc/xprtsock.h>
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-27 14:01:27 +04:00
										 |  |  | #include "netns.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int sunrpc_net_id; | 
					
						
							| 
									
										
										
										
											2012-01-19 21:42:37 +04:00
										 |  |  | EXPORT_SYMBOL_GPL(sunrpc_net_id); | 
					
						
							| 
									
										
										
										
											2010-09-27 14:01:27 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  | static __net_init int sunrpc_init_net(struct net *net) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-09-27 14:01:58 +04:00
										 |  |  | 	int err; | 
					
						
							| 
									
										
										
										
											2012-01-12 22:07:51 +04:00
										 |  |  | 	struct sunrpc_net *sn = net_generic(net, sunrpc_net_id); | 
					
						
							| 
									
										
										
										
											2010-09-27 14:01:58 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	err = rpc_proc_init(net); | 
					
						
							|  |  |  | 	if (err) | 
					
						
							|  |  |  | 		goto err_proc; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-27 14:02:29 +04:00
										 |  |  | 	err = ip_map_cache_create(net); | 
					
						
							|  |  |  | 	if (err) | 
					
						
							|  |  |  | 		goto err_ipmap; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-19 21:42:29 +04:00
										 |  |  | 	err = unix_gid_cache_create(net); | 
					
						
							|  |  |  | 	if (err) | 
					
						
							|  |  |  | 		goto err_unixgid; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-14 07:25:17 -05:00
										 |  |  | 	err = rpc_pipefs_init_net(net); | 
					
						
							|  |  |  | 	if (err) | 
					
						
							|  |  |  | 		goto err_pipefs; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-12 22:07:51 +04:00
										 |  |  | 	INIT_LIST_HEAD(&sn->all_clients); | 
					
						
							|  |  |  | 	spin_lock_init(&sn->rpc_client_lock); | 
					
						
							| 
									
										
										
										
											2012-02-16 17:42:12 +04:00
										 |  |  | 	spin_lock_init(&sn->rpcb_clnt_lock); | 
					
						
							| 
									
										
										
										
											2010-09-27 14:01:27 +04:00
										 |  |  | 	return 0; | 
					
						
							| 
									
										
										
										
											2010-09-27 14:01:58 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-14 07:25:17 -05:00
										 |  |  | err_pipefs: | 
					
						
							|  |  |  | 	unix_gid_cache_destroy(net); | 
					
						
							| 
									
										
										
										
											2012-01-19 21:42:29 +04:00
										 |  |  | err_unixgid: | 
					
						
							|  |  |  | 	ip_map_cache_destroy(net); | 
					
						
							| 
									
										
										
										
											2010-09-27 14:02:29 +04:00
										 |  |  | err_ipmap: | 
					
						
							|  |  |  | 	rpc_proc_exit(net); | 
					
						
							| 
									
										
										
										
											2010-09-27 14:01:58 +04:00
										 |  |  | err_proc: | 
					
						
							|  |  |  | 	return err; | 
					
						
							| 
									
										
										
										
											2010-09-27 14:01:27 +04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static __net_exit void sunrpc_exit_net(struct net *net) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2013-11-14 07:25:17 -05:00
										 |  |  | 	rpc_pipefs_exit_net(net); | 
					
						
							| 
									
										
										
										
											2012-01-19 21:42:29 +04:00
										 |  |  | 	unix_gid_cache_destroy(net); | 
					
						
							| 
									
										
										
										
											2010-09-27 14:02:29 +04:00
										 |  |  | 	ip_map_cache_destroy(net); | 
					
						
							| 
									
										
										
										
											2010-09-27 14:01:58 +04:00
										 |  |  | 	rpc_proc_exit(net); | 
					
						
							| 
									
										
										
										
											2010-09-27 14:01:27 +04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static struct pernet_operations sunrpc_net_ops = { | 
					
						
							|  |  |  | 	.init = sunrpc_init_net, | 
					
						
							|  |  |  | 	.exit = sunrpc_exit_net, | 
					
						
							|  |  |  | 	.id = &sunrpc_net_id, | 
					
						
							|  |  |  | 	.size = sizeof(struct sunrpc_net), | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | static int __init | 
					
						
							|  |  |  | init_sunrpc(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-04-05 21:04:37 +04:00
										 |  |  | 	int err = rpc_init_mempool(); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	if (err) | 
					
						
							|  |  |  | 		goto out; | 
					
						
							| 
									
										
										
										
											2010-07-31 14:29:07 -04:00
										 |  |  | 	err = rpcauth_init_module(); | 
					
						
							|  |  |  | 	if (err) | 
					
						
							| 
									
										
										
										
											2012-04-05 21:04:37 +04:00
										 |  |  | 		goto out2; | 
					
						
							| 
									
										
										
										
											2010-09-27 14:01:27 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	cache_initialize(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	err = register_pernet_subsys(&sunrpc_net_ops); | 
					
						
							| 
									
										
										
										
											2012-04-05 21:04:37 +04:00
										 |  |  | 	if (err) | 
					
						
							|  |  |  | 		goto out3; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	err = register_rpc_pipefs(); | 
					
						
							| 
									
										
										
										
											2010-09-27 14:01:27 +04:00
										 |  |  | 	if (err) | 
					
						
							|  |  |  | 		goto out4; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #ifdef RPC_DEBUG
 | 
					
						
							|  |  |  | 	rpc_register_sysctl(); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2007-12-30 21:07:17 -06:00
										 |  |  | 	svc_init_xprt_sock();	/* svc sock transport */ | 
					
						
							|  |  |  | 	init_socket_xprt();	/* clnt sock transport */ | 
					
						
							| 
									
										
										
										
											2010-07-31 14:29:07 -04:00
										 |  |  | 	return 0; | 
					
						
							| 
									
										
										
										
											2010-09-27 14:01:27 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  | out4: | 
					
						
							| 
									
										
										
										
											2012-04-05 21:04:37 +04:00
										 |  |  | 	unregister_pernet_subsys(&sunrpc_net_ops); | 
					
						
							| 
									
										
										
										
											2010-07-31 14:29:07 -04:00
										 |  |  | out3: | 
					
						
							| 
									
										
										
										
											2012-04-05 21:04:37 +04:00
										 |  |  | 	rpcauth_remove_module(); | 
					
						
							| 
									
										
										
										
											2010-07-31 14:29:07 -04:00
										 |  |  | out2: | 
					
						
							| 
									
										
										
										
											2012-04-05 21:04:37 +04:00
										 |  |  | 	rpc_destroy_mempool(); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | out: | 
					
						
							|  |  |  | 	return err; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void __exit | 
					
						
							|  |  |  | cleanup_sunrpc(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2007-06-25 17:11:20 -04:00
										 |  |  | 	rpcauth_remove_module(); | 
					
						
							| 
									
										
										
										
											2006-12-05 16:35:51 -05:00
										 |  |  | 	cleanup_socket_xprt(); | 
					
						
							| 
									
										
										
										
											2007-12-30 21:07:17 -06:00
										 |  |  | 	svc_cleanup_xprt_sock(); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	unregister_rpc_pipefs(); | 
					
						
							|  |  |  | 	rpc_destroy_mempool(); | 
					
						
							| 
									
										
										
										
											2010-09-27 14:01:27 +04:00
										 |  |  | 	unregister_pernet_subsys(&sunrpc_net_ops); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #ifdef RPC_DEBUG
 | 
					
						
							|  |  |  | 	rpc_unregister_sysctl(); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-06-26 10:45:58 +00:00
										 |  |  | 	rcu_barrier(); /* Wait for completion of call_rcu()'s */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | MODULE_LICENSE("GPL"); | 
					
						
							| 
									
										
										
										
											2009-08-21 08:17:56 -04:00
										 |  |  | fs_initcall(init_sunrpc); /* Ensure we're initialised before nfs */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | module_exit(cleanup_sunrpc); |