diff options
author | Denis V. Lunev <den@openvz.org> | 2008-01-28 17:41:19 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-01-28 18:08:07 -0500 |
commit | b7c6ba6eb1234e35a74fb8ba8123232a7b1ba9e4 (patch) | |
tree | 672c08c95229a6ac242ab12a5195dceddb0f3127 /net | |
parent | 4f84d82f7a623f8641af2574425c329431ff158f (diff) |
[NETNS]: Consolidate kernel netlink socket destruction.
Create a specific helper for netlink kernel socket disposal. This just
let the code look better and provides a ground for proper disposal
inside a namespace.
Signed-off-by: Denis V. Lunev <den@openvz.org>
Tested-by: Alexey Dobriyan <adobriyan@openvz.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net')
-rw-r--r-- | net/bridge/netfilter/ebt_ulog.c | 4 | ||||
-rw-r--r-- | net/core/rtnetlink.c | 2 | ||||
-rw-r--r-- | net/decnet/netfilter/dn_rtmsg.c | 4 | ||||
-rw-r--r-- | net/ipv4/fib_frontend.c | 2 | ||||
-rw-r--r-- | net/ipv4/inet_diag.c | 2 | ||||
-rw-r--r-- | net/ipv4/netfilter/ip_queue.c | 4 | ||||
-rw-r--r-- | net/ipv4/netfilter/ipt_ULOG.c | 4 | ||||
-rw-r--r-- | net/ipv6/netfilter/ip6_queue.c | 4 | ||||
-rw-r--r-- | net/netfilter/nfnetlink.c | 2 | ||||
-rw-r--r-- | net/netlink/af_netlink.c | 11 | ||||
-rw-r--r-- | net/xfrm/xfrm_user.c | 2 |
11 files changed, 26 insertions, 15 deletions
diff --git a/net/bridge/netfilter/ebt_ulog.c b/net/bridge/netfilter/ebt_ulog.c index b73ba28bcbe8..8e7b00b68d38 100644 --- a/net/bridge/netfilter/ebt_ulog.c +++ b/net/bridge/netfilter/ebt_ulog.c | |||
@@ -307,7 +307,7 @@ static int __init ebt_ulog_init(void) | |||
307 | if (!ebtulognl) | 307 | if (!ebtulognl) |
308 | ret = -ENOMEM; | 308 | ret = -ENOMEM; |
309 | else if ((ret = ebt_register_watcher(&ulog))) | 309 | else if ((ret = ebt_register_watcher(&ulog))) |
310 | sock_release(ebtulognl->sk_socket); | 310 | netlink_kernel_release(ebtulognl); |
311 | 311 | ||
312 | if (ret == 0) | 312 | if (ret == 0) |
313 | nf_log_register(PF_BRIDGE, &ebt_ulog_logger); | 313 | nf_log_register(PF_BRIDGE, &ebt_ulog_logger); |
@@ -333,7 +333,7 @@ static void __exit ebt_ulog_fini(void) | |||
333 | } | 333 | } |
334 | spin_unlock_bh(&ub->lock); | 334 | spin_unlock_bh(&ub->lock); |
335 | } | 335 | } |
336 | sock_release(ebtulognl->sk_socket); | 336 | netlink_kernel_release(ebtulognl); |
337 | } | 337 | } |
338 | 338 | ||
339 | module_init(ebt_ulog_init); | 339 | module_init(ebt_ulog_init); |
diff --git a/net/core/rtnetlink.c b/net/core/rtnetlink.c index a5f4f661fa62..02cf848f71d2 100644 --- a/net/core/rtnetlink.c +++ b/net/core/rtnetlink.c | |||
@@ -1384,7 +1384,7 @@ static void rtnetlink_net_exit(struct net *net) | |||
1384 | * free. | 1384 | * free. |
1385 | */ | 1385 | */ |
1386 | sk->sk_net = get_net(&init_net); | 1386 | sk->sk_net = get_net(&init_net); |
1387 | sock_release(net->rtnl->sk_socket); | 1387 | netlink_kernel_release(net->rtnl); |
1388 | net->rtnl = NULL; | 1388 | net->rtnl = NULL; |
1389 | } | 1389 | } |
1390 | } | 1390 | } |
diff --git a/net/decnet/netfilter/dn_rtmsg.c b/net/decnet/netfilter/dn_rtmsg.c index 96375f2e64ff..6d2bd3202048 100644 --- a/net/decnet/netfilter/dn_rtmsg.c +++ b/net/decnet/netfilter/dn_rtmsg.c | |||
@@ -137,7 +137,7 @@ static int __init dn_rtmsg_init(void) | |||
137 | 137 | ||
138 | rv = nf_register_hook(&dnrmg_ops); | 138 | rv = nf_register_hook(&dnrmg_ops); |
139 | if (rv) { | 139 | if (rv) { |
140 | sock_release(dnrmg->sk_socket); | 140 | netlink_kernel_release(dnrmg); |
141 | } | 141 | } |
142 | 142 | ||
143 | return rv; | 143 | return rv; |
@@ -146,7 +146,7 @@ static int __init dn_rtmsg_init(void) | |||
146 | static void __exit dn_rtmsg_fini(void) | 146 | static void __exit dn_rtmsg_fini(void) |
147 | { | 147 | { |
148 | nf_unregister_hook(&dnrmg_ops); | 148 | nf_unregister_hook(&dnrmg_ops); |
149 | sock_release(dnrmg->sk_socket); | 149 | netlink_kernel_release(dnrmg); |
150 | } | 150 | } |
151 | 151 | ||
152 | 152 | ||
diff --git a/net/ipv4/fib_frontend.c b/net/ipv4/fib_frontend.c index 4e5216e9aacb..e787d2151152 100644 --- a/net/ipv4/fib_frontend.c +++ b/net/ipv4/fib_frontend.c | |||
@@ -881,7 +881,7 @@ static void nl_fib_lookup_exit(struct net *net) | |||
881 | * initial network namespace. So the socket will be safe to free. | 881 | * initial network namespace. So the socket will be safe to free. |
882 | */ | 882 | */ |
883 | net->ipv4.fibnl->sk_net = get_net(&init_net); | 883 | net->ipv4.fibnl->sk_net = get_net(&init_net); |
884 | sock_release(net->ipv4.fibnl->sk_socket); | 884 | netlink_kernel_release(net->ipv4.fibnl); |
885 | } | 885 | } |
886 | 886 | ||
887 | static void fib_disable_ip(struct net_device *dev, int force) | 887 | static void fib_disable_ip(struct net_device *dev, int force) |
diff --git a/net/ipv4/inet_diag.c b/net/ipv4/inet_diag.c index e468e7a7aac4..605ed2cd7972 100644 --- a/net/ipv4/inet_diag.c +++ b/net/ipv4/inet_diag.c | |||
@@ -935,7 +935,7 @@ out_free_table: | |||
935 | 935 | ||
936 | static void __exit inet_diag_exit(void) | 936 | static void __exit inet_diag_exit(void) |
937 | { | 937 | { |
938 | sock_release(idiagnl->sk_socket); | 938 | netlink_kernel_release(idiagnl); |
939 | kfree(inet_diag_table); | 939 | kfree(inet_diag_table); |
940 | } | 940 | } |
941 | 941 | ||
diff --git a/net/ipv4/netfilter/ip_queue.c b/net/ipv4/netfilter/ip_queue.c index 7361315f20c6..5109839da222 100644 --- a/net/ipv4/netfilter/ip_queue.c +++ b/net/ipv4/netfilter/ip_queue.c | |||
@@ -605,7 +605,7 @@ cleanup_sysctl: | |||
605 | unregister_netdevice_notifier(&ipq_dev_notifier); | 605 | unregister_netdevice_notifier(&ipq_dev_notifier); |
606 | proc_net_remove(&init_net, IPQ_PROC_FS_NAME); | 606 | proc_net_remove(&init_net, IPQ_PROC_FS_NAME); |
607 | cleanup_ipqnl: | 607 | cleanup_ipqnl: |
608 | sock_release(ipqnl->sk_socket); | 608 | netlink_kernel_release(ipqnl); |
609 | mutex_lock(&ipqnl_mutex); | 609 | mutex_lock(&ipqnl_mutex); |
610 | mutex_unlock(&ipqnl_mutex); | 610 | mutex_unlock(&ipqnl_mutex); |
611 | 611 | ||
@@ -624,7 +624,7 @@ static void __exit ip_queue_fini(void) | |||
624 | unregister_netdevice_notifier(&ipq_dev_notifier); | 624 | unregister_netdevice_notifier(&ipq_dev_notifier); |
625 | proc_net_remove(&init_net, IPQ_PROC_FS_NAME); | 625 | proc_net_remove(&init_net, IPQ_PROC_FS_NAME); |
626 | 626 | ||
627 | sock_release(ipqnl->sk_socket); | 627 | netlink_kernel_release(ipqnl); |
628 | mutex_lock(&ipqnl_mutex); | 628 | mutex_lock(&ipqnl_mutex); |
629 | mutex_unlock(&ipqnl_mutex); | 629 | mutex_unlock(&ipqnl_mutex); |
630 | 630 | ||
diff --git a/net/ipv4/netfilter/ipt_ULOG.c b/net/ipv4/netfilter/ipt_ULOG.c index fa24efaf3eaa..b192756c6d0d 100644 --- a/net/ipv4/netfilter/ipt_ULOG.c +++ b/net/ipv4/netfilter/ipt_ULOG.c | |||
@@ -415,7 +415,7 @@ static int __init ulog_tg_init(void) | |||
415 | 415 | ||
416 | ret = xt_register_target(&ulog_tg_reg); | 416 | ret = xt_register_target(&ulog_tg_reg); |
417 | if (ret < 0) { | 417 | if (ret < 0) { |
418 | sock_release(nflognl->sk_socket); | 418 | netlink_kernel_release(nflognl); |
419 | return ret; | 419 | return ret; |
420 | } | 420 | } |
421 | if (nflog) | 421 | if (nflog) |
@@ -434,7 +434,7 @@ static void __exit ulog_tg_exit(void) | |||
434 | if (nflog) | 434 | if (nflog) |
435 | nf_log_unregister(&ipt_ulog_logger); | 435 | nf_log_unregister(&ipt_ulog_logger); |
436 | xt_unregister_target(&ulog_tg_reg); | 436 | xt_unregister_target(&ulog_tg_reg); |
437 | sock_release(nflognl->sk_socket); | 437 | netlink_kernel_release(nflognl); |
438 | 438 | ||
439 | /* remove pending timers and free allocated skb's */ | 439 | /* remove pending timers and free allocated skb's */ |
440 | for (i = 0; i < ULOG_MAXNLGROUPS; i++) { | 440 | for (i = 0; i < ULOG_MAXNLGROUPS; i++) { |
diff --git a/net/ipv6/netfilter/ip6_queue.c b/net/ipv6/netfilter/ip6_queue.c index a20db0bb5a1f..56b4ea6d29ed 100644 --- a/net/ipv6/netfilter/ip6_queue.c +++ b/net/ipv6/netfilter/ip6_queue.c | |||
@@ -609,7 +609,7 @@ cleanup_sysctl: | |||
609 | proc_net_remove(&init_net, IPQ_PROC_FS_NAME); | 609 | proc_net_remove(&init_net, IPQ_PROC_FS_NAME); |
610 | 610 | ||
611 | cleanup_ipqnl: | 611 | cleanup_ipqnl: |
612 | sock_release(ipqnl->sk_socket); | 612 | netlink_kernel_release(ipqnl); |
613 | mutex_lock(&ipqnl_mutex); | 613 | mutex_lock(&ipqnl_mutex); |
614 | mutex_unlock(&ipqnl_mutex); | 614 | mutex_unlock(&ipqnl_mutex); |
615 | 615 | ||
@@ -628,7 +628,7 @@ static void __exit ip6_queue_fini(void) | |||
628 | unregister_netdevice_notifier(&ipq_dev_notifier); | 628 | unregister_netdevice_notifier(&ipq_dev_notifier); |
629 | proc_net_remove(&init_net, IPQ_PROC_FS_NAME); | 629 | proc_net_remove(&init_net, IPQ_PROC_FS_NAME); |
630 | 630 | ||
631 | sock_release(ipqnl->sk_socket); | 631 | netlink_kernel_release(ipqnl); |
632 | mutex_lock(&ipqnl_mutex); | 632 | mutex_lock(&ipqnl_mutex); |
633 | mutex_unlock(&ipqnl_mutex); | 633 | mutex_unlock(&ipqnl_mutex); |
634 | 634 | ||
diff --git a/net/netfilter/nfnetlink.c b/net/netfilter/nfnetlink.c index 2128542995f7..b75c9c4a995d 100644 --- a/net/netfilter/nfnetlink.c +++ b/net/netfilter/nfnetlink.c | |||
@@ -179,7 +179,7 @@ static void nfnetlink_rcv(struct sk_buff *skb) | |||
179 | static void __exit nfnetlink_exit(void) | 179 | static void __exit nfnetlink_exit(void) |
180 | { | 180 | { |
181 | printk("Removing netfilter NETLINK layer.\n"); | 181 | printk("Removing netfilter NETLINK layer.\n"); |
182 | sock_release(nfnl->sk_socket); | 182 | netlink_kernel_release(nfnl); |
183 | return; | 183 | return; |
184 | } | 184 | } |
185 | 185 | ||
diff --git a/net/netlink/af_netlink.c b/net/netlink/af_netlink.c index 29fef558aab6..626a58206298 100644 --- a/net/netlink/af_netlink.c +++ b/net/netlink/af_netlink.c | |||
@@ -1405,6 +1405,17 @@ out_sock_release: | |||
1405 | } | 1405 | } |
1406 | EXPORT_SYMBOL(netlink_kernel_create); | 1406 | EXPORT_SYMBOL(netlink_kernel_create); |
1407 | 1407 | ||
1408 | |||
1409 | void | ||
1410 | netlink_kernel_release(struct sock *sk) | ||
1411 | { | ||
1412 | if (sk == NULL || sk->sk_socket == NULL) | ||
1413 | return; | ||
1414 | sock_release(sk->sk_socket); | ||
1415 | } | ||
1416 | EXPORT_SYMBOL(netlink_kernel_release); | ||
1417 | |||
1418 | |||
1408 | /** | 1419 | /** |
1409 | * netlink_change_ngroups - change number of multicast groups | 1420 | * netlink_change_ngroups - change number of multicast groups |
1410 | * | 1421 | * |
diff --git a/net/xfrm/xfrm_user.c b/net/xfrm/xfrm_user.c index 35fc16ae50ac..e0ccdf267813 100644 --- a/net/xfrm/xfrm_user.c +++ b/net/xfrm/xfrm_user.c | |||
@@ -2420,7 +2420,7 @@ static void __exit xfrm_user_exit(void) | |||
2420 | xfrm_unregister_km(&netlink_mgr); | 2420 | xfrm_unregister_km(&netlink_mgr); |
2421 | rcu_assign_pointer(xfrm_nl, NULL); | 2421 | rcu_assign_pointer(xfrm_nl, NULL); |
2422 | synchronize_rcu(); | 2422 | synchronize_rcu(); |
2423 | sock_release(nlsk->sk_socket); | 2423 | netlink_kernel_release(nlsk); |
2424 | } | 2424 | } |
2425 | 2425 | ||
2426 | module_init(xfrm_user_init); | 2426 | module_init(xfrm_user_init); |