2005-04-17 02:20:36 +04: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 21:47:31 +04:00
# include <linux/sunrpc/xprtsock.h>
2005-04-17 02:20:36 +04: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 16:25:17 +04: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 16:25:17 +04: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 16:25:17 +04: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-17 02:20:36 +04:00
static int __init
init_sunrpc ( void )
{
2012-04-05 21:04:37 +04:00
int err = rpc_init_mempool ( ) ;
2005-04-17 02:20:36 +04:00
if ( err )
goto out ;
2010-07-31 22: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 ;
2014-11-26 22:44:43 +03:00
2015-03-31 19:03:28 +03:00
sunrpc_debugfs_init ( ) ;
2014-11-18 00:58:04 +03:00
# if IS_ENABLED(CONFIG_SUNRPC_DEBUG)
2005-04-17 02:20:36 +04:00
rpc_register_sysctl ( ) ;
# endif
2007-12-31 06:07:17 +03:00
svc_init_xprt_sock ( ) ; /* svc sock transport */
init_socket_xprt ( ) ; /* clnt sock transport */
2010-07-31 22: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 22:29:07 +04:00
out3 :
2012-04-05 21:04:37 +04:00
rpcauth_remove_module ( ) ;
2010-07-31 22:29:07 +04:00
out2 :
2012-04-05 21:04:37 +04:00
rpc_destroy_mempool ( ) ;
2005-04-17 02:20:36 +04:00
out :
return err ;
}
static void __exit
cleanup_sunrpc ( void )
{
2007-06-26 01:11:20 +04:00
rpcauth_remove_module ( ) ;
2006-12-06 00:35:51 +03:00
cleanup_socket_xprt ( ) ;
2007-12-31 06:07:17 +03:00
svc_cleanup_xprt_sock ( ) ;
2014-11-26 22:44:43 +03:00
sunrpc_debugfs_exit ( ) ;
2005-04-17 02:20:36 +04:00
unregister_rpc_pipefs ( ) ;
rpc_destroy_mempool ( ) ;
2010-09-27 14:01:27 +04:00
unregister_pernet_subsys ( & sunrpc_net_ops ) ;
2014-11-18 00:58:04 +03:00
# if IS_ENABLED(CONFIG_SUNRPC_DEBUG)
2005-04-17 02:20:36 +04:00
rpc_unregister_sysctl ( ) ;
# endif
2009-06-26 14:45:58 +04:00
rcu_barrier ( ) ; /* Wait for completion of call_rcu()'s */
2005-04-17 02:20:36 +04:00
}
MODULE_LICENSE ( " GPL " ) ;
2009-08-21 16:17:56 +04:00
fs_initcall ( init_sunrpc ) ; /* Ensure we're initialised before nfs */
2005-04-17 02:20:36 +04:00
module_exit ( cleanup_sunrpc ) ;