forked from luck/tmp_suning_uos_patched
ipv6: statically link register_inet6addr_notifier()
Tomas reported the following build error: net/built-in.o: In function `ieee80211_unregister_hw': (.text+0x10f0e1): undefined reference to `unregister_inet6addr_notifier' net/built-in.o: In function `ieee80211_register_hw': (.text+0x10f610): undefined reference to `register_inet6addr_notifier' make: *** [vmlinux] Error 1 when built IPv6 as a module. So we have to statically link these symbols. Reported-by: Tomas Melin <tomas.melin@iki.fi> Cc: Tomas Melin <tomas.melin@iki.fi> Cc: "David S. Miller" <davem@davemloft.net> Cc: YOSHIFUJI Hidaki <yoshfuji@linux-ipv6.org> Signed-off-by: Cong Wang <amwang@redhat.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
2e0cbf2cc2
commit
f88c91ddba
|
@ -199,6 +199,7 @@ extern bool ipv6_chk_acast_addr(struct net *net, struct net_device *dev,
|
||||||
/* Device notifier */
|
/* Device notifier */
|
||||||
extern int register_inet6addr_notifier(struct notifier_block *nb);
|
extern int register_inet6addr_notifier(struct notifier_block *nb);
|
||||||
extern int unregister_inet6addr_notifier(struct notifier_block *nb);
|
extern int unregister_inet6addr_notifier(struct notifier_block *nb);
|
||||||
|
extern int inet6addr_notifier_call_chain(unsigned long val, void *v);
|
||||||
|
|
||||||
extern void inet6_netconf_notify_devconf(struct net *net, int type, int ifindex,
|
extern void inet6_netconf_notify_devconf(struct net *net, int type, int ifindex,
|
||||||
struct ipv6_devconf *devconf);
|
struct ipv6_devconf *devconf);
|
||||||
|
|
|
@ -168,8 +168,6 @@ static void inet6_prefix_notify(int event, struct inet6_dev *idev,
|
||||||
static bool ipv6_chk_same_addr(struct net *net, const struct in6_addr *addr,
|
static bool ipv6_chk_same_addr(struct net *net, const struct in6_addr *addr,
|
||||||
struct net_device *dev);
|
struct net_device *dev);
|
||||||
|
|
||||||
static ATOMIC_NOTIFIER_HEAD(inet6addr_chain);
|
|
||||||
|
|
||||||
static struct ipv6_devconf ipv6_devconf __read_mostly = {
|
static struct ipv6_devconf ipv6_devconf __read_mostly = {
|
||||||
.forwarding = 0,
|
.forwarding = 0,
|
||||||
.hop_limit = IPV6_DEFAULT_HOPLIMIT,
|
.hop_limit = IPV6_DEFAULT_HOPLIMIT,
|
||||||
|
@ -837,7 +835,7 @@ ipv6_add_addr(struct inet6_dev *idev, const struct in6_addr *addr, int pfxlen,
|
||||||
rcu_read_unlock_bh();
|
rcu_read_unlock_bh();
|
||||||
|
|
||||||
if (likely(err == 0))
|
if (likely(err == 0))
|
||||||
atomic_notifier_call_chain(&inet6addr_chain, NETDEV_UP, ifa);
|
inet6addr_notifier_call_chain(NETDEV_UP, ifa);
|
||||||
else {
|
else {
|
||||||
kfree(ifa);
|
kfree(ifa);
|
||||||
ifa = ERR_PTR(err);
|
ifa = ERR_PTR(err);
|
||||||
|
@ -927,7 +925,7 @@ static void ipv6_del_addr(struct inet6_ifaddr *ifp)
|
||||||
|
|
||||||
ipv6_ifa_notify(RTM_DELADDR, ifp);
|
ipv6_ifa_notify(RTM_DELADDR, ifp);
|
||||||
|
|
||||||
atomic_notifier_call_chain(&inet6addr_chain, NETDEV_DOWN, ifp);
|
inet6addr_notifier_call_chain(NETDEV_DOWN, ifp);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Purge or update corresponding prefix
|
* Purge or update corresponding prefix
|
||||||
|
@ -2988,7 +2986,7 @@ static int addrconf_ifdown(struct net_device *dev, int how)
|
||||||
|
|
||||||
if (state != INET6_IFADDR_STATE_DEAD) {
|
if (state != INET6_IFADDR_STATE_DEAD) {
|
||||||
__ipv6_ifa_notify(RTM_DELADDR, ifa);
|
__ipv6_ifa_notify(RTM_DELADDR, ifa);
|
||||||
atomic_notifier_call_chain(&inet6addr_chain, NETDEV_DOWN, ifa);
|
inet6addr_notifier_call_chain(NETDEV_DOWN, ifa);
|
||||||
}
|
}
|
||||||
in6_ifa_put(ifa);
|
in6_ifa_put(ifa);
|
||||||
|
|
||||||
|
@ -4869,22 +4867,6 @@ static struct pernet_operations addrconf_ops = {
|
||||||
.exit = addrconf_exit_net,
|
.exit = addrconf_exit_net,
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
|
||||||
* Device notifier
|
|
||||||
*/
|
|
||||||
|
|
||||||
int register_inet6addr_notifier(struct notifier_block *nb)
|
|
||||||
{
|
|
||||||
return atomic_notifier_chain_register(&inet6addr_chain, nb);
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL(register_inet6addr_notifier);
|
|
||||||
|
|
||||||
int unregister_inet6addr_notifier(struct notifier_block *nb)
|
|
||||||
{
|
|
||||||
return atomic_notifier_chain_unregister(&inet6addr_chain, nb);
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL(unregister_inet6addr_notifier);
|
|
||||||
|
|
||||||
static struct rtnl_af_ops inet6_ops = {
|
static struct rtnl_af_ops inet6_ops = {
|
||||||
.family = AF_INET6,
|
.family = AF_INET6,
|
||||||
.fill_link_af = inet6_fill_link_af,
|
.fill_link_af = inet6_fill_link_af,
|
||||||
|
|
|
@ -78,3 +78,22 @@ int __ipv6_addr_type(const struct in6_addr *addr)
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(__ipv6_addr_type);
|
EXPORT_SYMBOL(__ipv6_addr_type);
|
||||||
|
|
||||||
|
static ATOMIC_NOTIFIER_HEAD(inet6addr_chain);
|
||||||
|
|
||||||
|
int register_inet6addr_notifier(struct notifier_block *nb)
|
||||||
|
{
|
||||||
|
return atomic_notifier_chain_register(&inet6addr_chain, nb);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(register_inet6addr_notifier);
|
||||||
|
|
||||||
|
int unregister_inet6addr_notifier(struct notifier_block *nb)
|
||||||
|
{
|
||||||
|
return atomic_notifier_chain_unregister(&inet6addr_chain, nb);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(unregister_inet6addr_notifier);
|
||||||
|
|
||||||
|
int inet6addr_notifier_call_chain(unsigned long val, void *v)
|
||||||
|
{
|
||||||
|
return atomic_notifier_call_chain(&inet6addr_chain, val, v);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(inet6addr_notifier_call_chain);
|
||||||
|
|
Loading…
Reference in New Issue
Block a user