aboutsummaryrefslogtreecommitdiffstats
path: root/net/unix/af_unix.c
diff options
context:
space:
mode:
authorPavel Emelyanov <xemul@openvz.org>2007-12-01 07:51:01 -0500
committerDavid S. Miller <davem@davemloft.net>2008-01-28 17:55:23 -0500
commit1597fbc0faf88c42edb3fe42e92e53b83c3f120e (patch)
tree17a56a96af0e00a1af452f0530997585803b6c7b /net/unix/af_unix.c
parent1d430b913c2e6293a80a4a422406bc9489a476ad (diff)
[UNIX]: Make the unix sysctl tables per-namespace
This is the core. * add the ctl_table_header on the struct net; * make the unix_sysctl_register and _unregister clone the table; * moves calls to them into per-net init and exit callbacks; * move the .data pointer in the proper place. Signed-off-by: Pavel Emelyanov <xemul@openvz.org> Acked-by: Eric W. Biederman <ebiederm@xmission.com> Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/unix/af_unix.c')
-rw-r--r--net/unix/af_unix.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/net/unix/af_unix.c b/net/unix/af_unix.c
index 73620d61762b..b8a2189fb5c0 100644
--- a/net/unix/af_unix.c
+++ b/net/unix/af_unix.c
@@ -2139,10 +2139,14 @@ static int unix_net_init(struct net *net)
2139 int error = -ENOMEM; 2139 int error = -ENOMEM;
2140 2140
2141 net->sysctl_unix_max_dgram_qlen = 10; 2141 net->sysctl_unix_max_dgram_qlen = 10;
2142 if (unix_sysctl_register(net))
2143 goto out;
2142 2144
2143#ifdef CONFIG_PROC_FS 2145#ifdef CONFIG_PROC_FS
2144 if (!proc_net_fops_create(net, "unix", 0, &unix_seq_fops)) 2146 if (!proc_net_fops_create(net, "unix", 0, &unix_seq_fops)) {
2147 unix_sysctl_unregister(net);
2145 goto out; 2148 goto out;
2149 }
2146#endif 2150#endif
2147 error = 0; 2151 error = 0;
2148out: 2152out:
@@ -2151,6 +2155,7 @@ out:
2151 2155
2152static void unix_net_exit(struct net *net) 2156static void unix_net_exit(struct net *net)
2153{ 2157{
2158 unix_sysctl_unregister(net);
2154 proc_net_remove(net, "unix"); 2159 proc_net_remove(net, "unix");
2155} 2160}
2156 2161
@@ -2175,7 +2180,6 @@ static int __init af_unix_init(void)
2175 2180
2176 sock_register(&unix_family_ops); 2181 sock_register(&unix_family_ops);
2177 register_pernet_subsys(&unix_net_ops); 2182 register_pernet_subsys(&unix_net_ops);
2178 unix_sysctl_register(&init_net);
2179out: 2183out:
2180 return rc; 2184 return rc;
2181} 2185}
@@ -2183,7 +2187,6 @@ out:
2183static void __exit af_unix_exit(void) 2187static void __exit af_unix_exit(void)
2184{ 2188{
2185 sock_unregister(PF_UNIX); 2189 sock_unregister(PF_UNIX);
2186 unix_sysctl_unregister(&init_net);
2187 proto_unregister(&unix_proto); 2190 proto_unregister(&unix_proto);
2188 unregister_pernet_subsys(&unix_net_ops); 2191 unregister_pernet_subsys(&unix_net_ops);
2189} 2192}