Run duplicate address detection again if an existing address gets updated from userland that was marked duplicated or tentative.
Otherwise we would just lose the duplicated / tentative state and assume that the address is now unique and usable. OK? diff --git in6.c in6.c index 1c5ec065aa5..b347ec74621 100644 --- in6.c +++ in6.c @@ -420,15 +420,15 @@ in6_ioctl(u_long cmd, caddr_t data, struct ifnet *ifp, int privileged) break; } + /* Perform DAD, if needed. */ + if (ia6->ia6_flags & IN6_IFF_TENTATIVE) + nd6_dad_start(&ia6->ia_ifa); + if (!newifaddr) { dohooks(ifp->if_addrhooks, 0); break; } - /* Perform DAD, if needed. */ - if (ia6->ia6_flags & IN6_IFF_TENTATIVE) - nd6_dad_start(&ia6->ia_ifa); - plen = in6_mask2len(&ia6->ia_prefixmask.sin6_addr, NULL); if ((ifp->if_flags & IFF_LOOPBACK) || plen == 128) { dohooks(ifp->if_addrhooks, 0); @@ -655,6 +655,9 @@ in6_update_ifa(struct ifnet *ifp, struct in6_aliasreq *ifra, if ((error = in6_ifinit(ifp, ia6, hostIsNew)) != 0) goto unlink; + /* re-run DAD */ + if (ia6->ia6_flags & (IN6_IFF_TENTATIVE|IN6_IFF_DUPLICATED)) + ifra->ifra_flags |= IN6_IFF_TENTATIVE; /* * configure address flags. */ -- I'm not entirely sure you are real.