Files
linux-apfs/net/sunrpc/sunrpc_syms.c
T

121 lines
2.2 KiB
C
Raw Normal View History

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;
static __net_init int sunrpc_init_net(struct net *net)
{
int err;
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;
2010-09-27 14:01:27 +04:00
return 0;
2010-09-27 14:02:29 +04:00
err_ipmap:
rpc_proc_exit(net);
err_proc:
return err;
2010-09-27 14:01:27 +04:00
}
static __net_exit void sunrpc_exit_net(struct net *net)
{
2010-09-27 14:02:29 +04:00
ip_map_cache_destroy(net);
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),
};
2010-09-27 14:02:29 +04:00
extern struct cache_detail unix_gid_cache;
2005-04-16 15:20:36 -07:00
extern void cleanup_rpcb_clnt(void);
2005-04-16 15:20:36 -07:00
static int __init
init_sunrpc(void)
{
int err = register_rpc_pipefs();
if (err)
goto out;
2007-05-09 02:34:51 -07:00
err = rpc_init_mempool();
if (err)
goto out2;
err = rpcauth_init_module();
if (err)
goto out3;
2010-09-27 14:01:27 +04:00
cache_initialize();
err = register_pernet_subsys(&sunrpc_net_ops);
if (err)
goto out4;
2005-04-16 15:20:36 -07:00
#ifdef RPC_DEBUG
rpc_register_sysctl();
#endif
cache_register(&unix_gid_cache);
2007-12-30 21:07:17 -06:00
svc_init_xprt_sock(); /* svc sock transport */
init_socket_xprt(); /* clnt sock transport */
return 0;
2010-09-27 14:01:27 +04:00
out4:
rpcauth_remove_module();
out3:
rpc_destroy_mempool();
out2:
unregister_rpc_pipefs();
2005-04-16 15:20:36 -07:00
out:
return err;
}
static void __exit
cleanup_sunrpc(void)
{
cleanup_rpcb_clnt();
rpcauth_remove_module();
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();
cache_unregister(&unix_gid_cache);
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");
fs_initcall(init_sunrpc); /* Ensure we're initialised before nfs */
2005-04-16 15:20:36 -07:00
module_exit(cleanup_sunrpc);