diff options
author | Pavel Emelyanov <xemul@parallels.com> | 2010-09-27 06:01:27 -0400 |
---|---|---|
committer | J. Bruce Fields <bfields@redhat.com> | 2010-09-27 10:16:12 -0400 |
commit | 2f72c9b73730c335381b13e2bd221abe1acea394 (patch) | |
tree | c8b59e83724b665bfa4d5776ba4f734f32451858 | |
parent | 4fb8518bdac8e85f6580ea3f586adf396cd472bc (diff) |
sunrpc: The per-net skeleton
Register empty per-net operations for the sunrpc layer.
Signed-off-by: Pavel Emelyanov <xemul@openvz.org>
Signed-off-by: J. Bruce Fields <bfields@redhat.com>
-rw-r--r-- | net/sunrpc/netns.h | 12 | ||||
-rw-r--r-- | net/sunrpc/sunrpc_syms.c | 31 |
2 files changed, 42 insertions, 1 deletions
diff --git a/net/sunrpc/netns.h b/net/sunrpc/netns.h new file mode 100644 index 000000000000..b2d18af2815e --- /dev/null +++ b/net/sunrpc/netns.h | |||
@@ -0,0 +1,12 @@ | |||
1 | #ifndef __SUNRPC_NETNS_H__ | ||
2 | #define __SUNRPC_NETNS_H__ | ||
3 | |||
4 | #include <net/net_namespace.h> | ||
5 | #include <net/netns/generic.h> | ||
6 | |||
7 | struct sunrpc_net { | ||
8 | }; | ||
9 | |||
10 | extern int sunrpc_net_id; | ||
11 | |||
12 | #endif | ||
diff --git a/net/sunrpc/sunrpc_syms.c b/net/sunrpc/sunrpc_syms.c index c0d085013a2b..faa23229bd25 100644 --- a/net/sunrpc/sunrpc_syms.c +++ b/net/sunrpc/sunrpc_syms.c | |||
@@ -22,6 +22,26 @@ | |||
22 | #include <linux/sunrpc/rpc_pipe_fs.h> | 22 | #include <linux/sunrpc/rpc_pipe_fs.h> |
23 | #include <linux/sunrpc/xprtsock.h> | 23 | #include <linux/sunrpc/xprtsock.h> |
24 | 24 | ||
25 | #include "netns.h" | ||
26 | |||
27 | int sunrpc_net_id; | ||
28 | |||
29 | static __net_init int sunrpc_init_net(struct net *net) | ||
30 | { | ||
31 | return 0; | ||
32 | } | ||
33 | |||
34 | static __net_exit void sunrpc_exit_net(struct net *net) | ||
35 | { | ||
36 | } | ||
37 | |||
38 | static struct pernet_operations sunrpc_net_ops = { | ||
39 | .init = sunrpc_init_net, | ||
40 | .exit = sunrpc_exit_net, | ||
41 | .id = &sunrpc_net_id, | ||
42 | .size = sizeof(struct sunrpc_net), | ||
43 | }; | ||
44 | |||
25 | extern struct cache_detail ip_map_cache, unix_gid_cache; | 45 | extern struct cache_detail ip_map_cache, unix_gid_cache; |
26 | 46 | ||
27 | extern void cleanup_rpcb_clnt(void); | 47 | extern void cleanup_rpcb_clnt(void); |
@@ -38,18 +58,26 @@ init_sunrpc(void) | |||
38 | err = rpcauth_init_module(); | 58 | err = rpcauth_init_module(); |
39 | if (err) | 59 | if (err) |
40 | goto out3; | 60 | goto out3; |
61 | |||
62 | cache_initialize(); | ||
63 | |||
64 | err = register_pernet_subsys(&sunrpc_net_ops); | ||
65 | if (err) | ||
66 | goto out4; | ||
41 | #ifdef RPC_DEBUG | 67 | #ifdef RPC_DEBUG |
42 | rpc_register_sysctl(); | 68 | rpc_register_sysctl(); |
43 | #endif | 69 | #endif |
44 | #ifdef CONFIG_PROC_FS | 70 | #ifdef CONFIG_PROC_FS |
45 | rpc_proc_init(); | 71 | rpc_proc_init(); |
46 | #endif | 72 | #endif |
47 | cache_initialize(); | ||
48 | cache_register(&ip_map_cache); | 73 | cache_register(&ip_map_cache); |
49 | cache_register(&unix_gid_cache); | 74 | cache_register(&unix_gid_cache); |
50 | svc_init_xprt_sock(); /* svc sock transport */ | 75 | svc_init_xprt_sock(); /* svc sock transport */ |
51 | init_socket_xprt(); /* clnt sock transport */ | 76 | init_socket_xprt(); /* clnt sock transport */ |
52 | return 0; | 77 | return 0; |
78 | |||
79 | out4: | ||
80 | rpcauth_remove_module(); | ||
53 | out3: | 81 | out3: |
54 | rpc_destroy_mempool(); | 82 | rpc_destroy_mempool(); |
55 | out2: | 83 | out2: |
@@ -69,6 +97,7 @@ cleanup_sunrpc(void) | |||
69 | rpc_destroy_mempool(); | 97 | rpc_destroy_mempool(); |
70 | cache_unregister(&ip_map_cache); | 98 | cache_unregister(&ip_map_cache); |
71 | cache_unregister(&unix_gid_cache); | 99 | cache_unregister(&unix_gid_cache); |
100 | unregister_pernet_subsys(&sunrpc_net_ops); | ||
72 | #ifdef RPC_DEBUG | 101 | #ifdef RPC_DEBUG |
73 | rpc_unregister_sysctl(); | 102 | rpc_unregister_sysctl(); |
74 | #endif | 103 | #endif |