Rework r281868 to not skip RTM announces for tunneling interfaces.
This is direct commit to stable/10. Tested by: tuexen@
This commit is contained in:
parent
8707ccbe03
commit
200ce7d836
@ -155,8 +155,13 @@ in6_ifaddloop(struct ifaddr *ifa)
|
||||
|
||||
ia = ifa2ia6(ifa);
|
||||
ifp = ifa->ifa_ifp;
|
||||
if (nd6_need_cache(ifp) == 0)
|
||||
return;
|
||||
/*
|
||||
* initialize for rtmsg generation
|
||||
*/
|
||||
bzero(&gateway, sizeof(gateway));
|
||||
gateway.sdl_len = sizeof(gateway);
|
||||
gateway.sdl_family = AF_LINK;
|
||||
if (nd6_need_cache(ifp) != 0) {
|
||||
IF_AFDATA_LOCK(ifp);
|
||||
ifa->ifa_rtrequest = nd6_rtrequest;
|
||||
ln = lla_lookup(LLTABLE6(ifp), (LLE_CREATE | LLE_IFADDR |
|
||||
@ -165,19 +170,13 @@ in6_ifaddloop(struct ifaddr *ifa)
|
||||
if (ln != NULL) {
|
||||
ln->la_expire = 0; /* for IPv6 this means permanent */
|
||||
ln->ln_state = ND6_LLINFO_REACHABLE;
|
||||
/*
|
||||
* initialize for rtmsg generation
|
||||
*/
|
||||
bzero(&gateway, sizeof(gateway));
|
||||
gateway.sdl_len = sizeof(gateway);
|
||||
gateway.sdl_family = AF_LINK;
|
||||
gateway.sdl_nlen = 0;
|
||||
|
||||
gateway.sdl_alen = 6;
|
||||
memcpy(gateway.sdl_data, &ln->ll_addr.mac_aligned,
|
||||
sizeof(ln->ll_addr));
|
||||
LLE_WUNLOCK(ln);
|
||||
}
|
||||
|
||||
}
|
||||
bzero(&rt, sizeof(rt));
|
||||
rt.rt_gateway = (struct sockaddr *)&gateway;
|
||||
memcpy(&mask, &ia->ia_prefixmask, sizeof(ia->ia_prefixmask));
|
||||
|
Loading…
x
Reference in New Issue
Block a user