Commit c127ea2c authored by Thomas Graf's avatar Thomas Graf Committed by David S. Miller

[IPv6]: Use rtnl registration interface

Signed-off-by: default avatarThomas Graf <tgraf@suug.ch>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent fa34ddd7
...@@ -219,8 +219,6 @@ extern void fib6_init(void); ...@@ -219,8 +219,6 @@ extern void fib6_init(void);
extern void fib6_rules_init(void); extern void fib6_rules_init(void);
extern void fib6_rules_cleanup(void); extern void fib6_rules_cleanup(void);
extern int fib6_rules_dump(struct sk_buff *,
struct netlink_callback *);
#endif #endif
#endif #endif
...@@ -116,12 +116,7 @@ extern void rt6_pmtu_discovery(struct in6_addr *daddr, ...@@ -116,12 +116,7 @@ extern void rt6_pmtu_discovery(struct in6_addr *daddr,
struct net_device *dev, struct net_device *dev,
u32 pmtu); u32 pmtu);
struct nlmsghdr;
struct netlink_callback; struct netlink_callback;
extern int inet6_dump_fib(struct sk_buff *skb, struct netlink_callback *cb);
extern int inet6_rtm_newroute(struct sk_buff *skb, struct nlmsghdr* nlh, void *arg);
extern int inet6_rtm_delroute(struct sk_buff *skb, struct nlmsghdr* nlh, void *arg);
extern int inet6_rtm_getroute(struct sk_buff *skb, struct nlmsghdr* nlh, void *arg);
struct rt6_rtnl_dump_arg struct rt6_rtnl_dump_arg
{ {
......
...@@ -3613,23 +3613,6 @@ static void inet6_prefix_notify(int event, struct inet6_dev *idev, ...@@ -3613,23 +3613,6 @@ static void inet6_prefix_notify(int event, struct inet6_dev *idev,
rtnl_set_sk_err(RTNLGRP_IPV6_PREFIX, err); rtnl_set_sk_err(RTNLGRP_IPV6_PREFIX, err);
} }
static struct rtnetlink_link inet6_rtnetlink_table[RTM_NR_MSGTYPES] = {
[RTM_GETLINK - RTM_BASE] = { .dumpit = inet6_dump_ifinfo, },
[RTM_NEWADDR - RTM_BASE] = { .doit = inet6_rtm_newaddr, },
[RTM_DELADDR - RTM_BASE] = { .doit = inet6_rtm_deladdr, },
[RTM_GETADDR - RTM_BASE] = { .doit = inet6_rtm_getaddr,
.dumpit = inet6_dump_ifaddr, },
[RTM_GETMULTICAST - RTM_BASE] = { .dumpit = inet6_dump_ifmcaddr, },
[RTM_GETANYCAST - RTM_BASE] = { .dumpit = inet6_dump_ifacaddr, },
[RTM_NEWROUTE - RTM_BASE] = { .doit = inet6_rtm_newroute, },
[RTM_DELROUTE - RTM_BASE] = { .doit = inet6_rtm_delroute, },
[RTM_GETROUTE - RTM_BASE] = { .doit = inet6_rtm_getroute,
.dumpit = inet6_dump_fib, },
#ifdef CONFIG_IPV6_MULTIPLE_TABLES
[RTM_GETRULE - RTM_BASE] = { .dumpit = fib6_rules_dump, },
#endif
};
static void __ipv6_ifa_notify(int event, struct inet6_ifaddr *ifp) static void __ipv6_ifa_notify(int event, struct inet6_ifaddr *ifp)
{ {
inet6_ifa_notify(event ? : RTM_NEWADDR, ifp); inet6_ifa_notify(event ? : RTM_NEWADDR, ifp);
...@@ -4149,7 +4132,18 @@ int __init addrconf_init(void) ...@@ -4149,7 +4132,18 @@ int __init addrconf_init(void)
register_netdevice_notifier(&ipv6_dev_notf); register_netdevice_notifier(&ipv6_dev_notf);
addrconf_verify(0); addrconf_verify(0);
rtnetlink_links[PF_INET6] = inet6_rtnetlink_table;
err = __rtnl_register(PF_INET6, RTM_GETLINK, NULL, inet6_dump_ifinfo);
if (err < 0)
goto errout;
/* Only the first call to __rtnl_register can fail */
__rtnl_register(PF_INET6, RTM_NEWADDR, inet6_rtm_newaddr, NULL);
__rtnl_register(PF_INET6, RTM_DELADDR, inet6_rtm_deladdr, NULL);
__rtnl_register(PF_INET6, RTM_GETADDR, inet6_rtm_getaddr, inet6_dump_ifaddr);
__rtnl_register(PF_INET6, RTM_GETMULTICAST, NULL, inet6_dump_ifmcaddr);
__rtnl_register(PF_INET6, RTM_GETANYCAST, NULL, inet6_dump_ifacaddr);
#ifdef CONFIG_SYSCTL #ifdef CONFIG_SYSCTL
addrconf_sysctl.sysctl_header = addrconf_sysctl.sysctl_header =
register_sysctl_table(addrconf_sysctl.addrconf_root_dir); register_sysctl_table(addrconf_sysctl.addrconf_root_dir);
...@@ -4157,6 +4151,10 @@ int __init addrconf_init(void) ...@@ -4157,6 +4151,10 @@ int __init addrconf_init(void)
#endif #endif
return 0; return 0;
errout:
unregister_netdevice_notifier(&ipv6_dev_notf);
return err;
} }
void __exit addrconf_cleanup(void) void __exit addrconf_cleanup(void)
...@@ -4168,7 +4166,6 @@ void __exit addrconf_cleanup(void) ...@@ -4168,7 +4166,6 @@ void __exit addrconf_cleanup(void)
unregister_netdevice_notifier(&ipv6_dev_notf); unregister_netdevice_notifier(&ipv6_dev_notf);
rtnetlink_links[PF_INET6] = NULL;
#ifdef CONFIG_SYSCTL #ifdef CONFIG_SYSCTL
addrconf_sysctl_unregister(&ipv6_devconf_dflt); addrconf_sysctl_unregister(&ipv6_devconf_dflt);
addrconf_sysctl_unregister(&ipv6_devconf); addrconf_sysctl_unregister(&ipv6_devconf);
......
...@@ -945,6 +945,8 @@ static void __exit inet6_exit(void) ...@@ -945,6 +945,8 @@ static void __exit inet6_exit(void)
{ {
/* First of all disallow new sockets creation. */ /* First of all disallow new sockets creation. */
sock_unregister(PF_INET6); sock_unregister(PF_INET6);
/* Disallow any further netlink messages */
rtnl_unregister_all(PF_INET6);
/* Cleanup code parts. */ /* Cleanup code parts. */
ipv6_packet_cleanup(); ipv6_packet_cleanup();
......
...@@ -216,7 +216,7 @@ static int fib6_rule_fill(struct fib_rule *rule, struct sk_buff *skb, ...@@ -216,7 +216,7 @@ static int fib6_rule_fill(struct fib_rule *rule, struct sk_buff *skb,
return -ENOBUFS; return -ENOBUFS;
} }
int fib6_rules_dump(struct sk_buff *skb, struct netlink_callback *cb) static int fib6_rules_dump(struct sk_buff *skb, struct netlink_callback *cb)
{ {
return fib_rules_dump(skb, cb, AF_INET6); return fib_rules_dump(skb, cb, AF_INET6);
} }
...@@ -255,9 +255,11 @@ void __init fib6_rules_init(void) ...@@ -255,9 +255,11 @@ void __init fib6_rules_init(void)
list_add_tail(&main_rule.common.list, &fib6_rules); list_add_tail(&main_rule.common.list, &fib6_rules);
fib_rules_register(&fib6_rules_ops); fib_rules_register(&fib6_rules_ops);
__rtnl_register(PF_INET6, RTM_GETRULE, NULL, fib6_rules_dump);
} }
void fib6_rules_cleanup(void) void fib6_rules_cleanup(void)
{ {
rtnl_unregister(PF_INET6, RTM_GETRULE);
fib_rules_unregister(&fib6_rules_ops); fib_rules_unregister(&fib6_rules_ops);
} }
...@@ -359,7 +359,7 @@ static int fib6_dump_table(struct fib6_table *table, struct sk_buff *skb, ...@@ -359,7 +359,7 @@ static int fib6_dump_table(struct fib6_table *table, struct sk_buff *skb,
return res; return res;
} }
int inet6_dump_fib(struct sk_buff *skb, struct netlink_callback *cb) static int inet6_dump_fib(struct sk_buff *skb, struct netlink_callback *cb)
{ {
unsigned int h, s_h; unsigned int h, s_h;
unsigned int e = 0, s_e; unsigned int e = 0, s_e;
...@@ -1486,6 +1486,8 @@ void __init fib6_init(void) ...@@ -1486,6 +1486,8 @@ void __init fib6_init(void)
NULL, NULL); NULL, NULL);
fib6_tables_init(); fib6_tables_init();
__rtnl_register(PF_INET6, RTM_GETROUTE, NULL, inet6_dump_fib);
} }
void fib6_gc_cleanup(void) void fib6_gc_cleanup(void)
......
...@@ -2015,7 +2015,7 @@ static int rtm_to_fib6_config(struct sk_buff *skb, struct nlmsghdr *nlh, ...@@ -2015,7 +2015,7 @@ static int rtm_to_fib6_config(struct sk_buff *skb, struct nlmsghdr *nlh,
return err; return err;
} }
int inet6_rtm_delroute(struct sk_buff *skb, struct nlmsghdr* nlh, void *arg) static int inet6_rtm_delroute(struct sk_buff *skb, struct nlmsghdr* nlh, void *arg)
{ {
struct fib6_config cfg; struct fib6_config cfg;
int err; int err;
...@@ -2027,7 +2027,7 @@ int inet6_rtm_delroute(struct sk_buff *skb, struct nlmsghdr* nlh, void *arg) ...@@ -2027,7 +2027,7 @@ int inet6_rtm_delroute(struct sk_buff *skb, struct nlmsghdr* nlh, void *arg)
return ip6_route_del(&cfg); return ip6_route_del(&cfg);
} }
int inet6_rtm_newroute(struct sk_buff *skb, struct nlmsghdr* nlh, void *arg) static int inet6_rtm_newroute(struct sk_buff *skb, struct nlmsghdr* nlh, void *arg)
{ {
struct fib6_config cfg; struct fib6_config cfg;
int err; int err;
...@@ -2164,7 +2164,7 @@ int rt6_dump_route(struct rt6_info *rt, void *p_arg) ...@@ -2164,7 +2164,7 @@ int rt6_dump_route(struct rt6_info *rt, void *p_arg)
prefix, NLM_F_MULTI); prefix, NLM_F_MULTI);
} }
int inet6_rtm_getroute(struct sk_buff *in_skb, struct nlmsghdr* nlh, void *arg) static int inet6_rtm_getroute(struct sk_buff *in_skb, struct nlmsghdr* nlh, void *arg)
{ {
struct nlattr *tb[RTA_MAX+1]; struct nlattr *tb[RTA_MAX+1];
struct rt6_info *rt; struct rt6_info *rt;
...@@ -2508,6 +2508,10 @@ void __init ip6_route_init(void) ...@@ -2508,6 +2508,10 @@ void __init ip6_route_init(void)
#ifdef CONFIG_IPV6_MULTIPLE_TABLES #ifdef CONFIG_IPV6_MULTIPLE_TABLES
fib6_rules_init(); fib6_rules_init();
#endif #endif
__rtnl_register(PF_INET6, RTM_NEWROUTE, inet6_rtm_newroute, NULL);
__rtnl_register(PF_INET6, RTM_DELROUTE, inet6_rtm_delroute, NULL);
__rtnl_register(PF_INET6, RTM_GETROUTE, inet6_rtm_getroute, NULL);
} }
void ip6_route_cleanup(void) void ip6_route_cleanup(void)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment