aboutsummaryrefslogtreecommitdiffstats
path: root/net/ipv6/addrconf.c
diff options
context:
space:
mode:
Diffstat (limited to 'net/ipv6/addrconf.c')
-rw-r--r--net/ipv6/addrconf.c24
1 files changed, 3 insertions, 21 deletions
diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c
index 28b61e89bbb8..d1ab6ab29a55 100644
--- a/net/ipv6/addrconf.c
+++ b/net/ipv6/addrconf.c
@@ -169,8 +169,6 @@ static void inet6_prefix_notify(int event, struct inet6_dev *idev,
169static bool ipv6_chk_same_addr(struct net *net, const struct in6_addr *addr, 169static bool ipv6_chk_same_addr(struct net *net, const struct in6_addr *addr,
170 struct net_device *dev); 170 struct net_device *dev);
171 171
172static ATOMIC_NOTIFIER_HEAD(inet6addr_chain);
173
174static struct ipv6_devconf ipv6_devconf __read_mostly = { 172static struct ipv6_devconf ipv6_devconf __read_mostly = {
175 .forwarding = 0, 173 .forwarding = 0,
176 .hop_limit = IPV6_DEFAULT_HOPLIMIT, 174 .hop_limit = IPV6_DEFAULT_HOPLIMIT,
@@ -910,7 +908,7 @@ out2:
910 rcu_read_unlock_bh(); 908 rcu_read_unlock_bh();
911 909
912 if (likely(err == 0)) 910 if (likely(err == 0))
913 atomic_notifier_call_chain(&inet6addr_chain, NETDEV_UP, ifa); 911 inet6addr_notifier_call_chain(NETDEV_UP, ifa);
914 else { 912 else {
915 kfree(ifa); 913 kfree(ifa);
916 ifa = ERR_PTR(err); 914 ifa = ERR_PTR(err);
@@ -1000,7 +998,7 @@ static void ipv6_del_addr(struct inet6_ifaddr *ifp)
1000 998
1001 ipv6_ifa_notify(RTM_DELADDR, ifp); 999 ipv6_ifa_notify(RTM_DELADDR, ifp);
1002 1000
1003 atomic_notifier_call_chain(&inet6addr_chain, NETDEV_DOWN, ifp); 1001 inet6addr_notifier_call_chain(NETDEV_DOWN, ifp);
1004 1002
1005 /* 1003 /*
1006 * Purge or update corresponding prefix 1004 * Purge or update corresponding prefix
@@ -3087,7 +3085,7 @@ static int addrconf_ifdown(struct net_device *dev, int how)
3087 3085
3088 if (state != INET6_IFADDR_STATE_DEAD) { 3086 if (state != INET6_IFADDR_STATE_DEAD) {
3089 __ipv6_ifa_notify(RTM_DELADDR, ifa); 3087 __ipv6_ifa_notify(RTM_DELADDR, ifa);
3090 atomic_notifier_call_chain(&inet6addr_chain, NETDEV_DOWN, ifa); 3088 inet6addr_notifier_call_chain(NETDEV_DOWN, ifa);
3091 } 3089 }
3092 in6_ifa_put(ifa); 3090 in6_ifa_put(ifa);
3093 3091
@@ -5054,22 +5052,6 @@ static struct pernet_operations addrconf_ops = {
5054 .exit = addrconf_exit_net, 5052 .exit = addrconf_exit_net,
5055}; 5053};
5056 5054
5057/*
5058 * Device notifier
5059 */
5060
5061int register_inet6addr_notifier(struct notifier_block *nb)
5062{
5063 return atomic_notifier_chain_register(&inet6addr_chain, nb);
5064}
5065EXPORT_SYMBOL(register_inet6addr_notifier);
5066
5067int unregister_inet6addr_notifier(struct notifier_block *nb)
5068{
5069 return atomic_notifier_chain_unregister(&inet6addr_chain, nb);
5070}
5071EXPORT_SYMBOL(unregister_inet6addr_notifier);
5072
5073static struct rtnl_af_ops inet6_ops = { 5055static struct rtnl_af_ops inet6_ops = {
5074 .family = AF_INET6, 5056 .family = AF_INET6,
5075 .fill_link_af = inet6_fill_link_af, 5057 .fill_link_af = inet6_fill_link_af,