+ return (ns_ifinit(ifp, ia,
+ (struct sockaddr_ns *)&ifr->ifr_addr, 1));
+
+ case SIOCDIFADDR:
+ ns_ifscrub(ifp, ia);
+ if ((ifa = ifp->if_addrlist) == (struct ifaddr *)ia)
+ ifp->if_addrlist = ifa->ifa_next;
+ else {
+ while (ifa->ifa_next &&
+ (ifa->ifa_next != (struct ifaddr *)ia))
+ ifa = ifa->ifa_next;
+ if (ifa->ifa_next)
+ ifa->ifa_next = ((struct ifaddr *)ia)->ifa_next;
+ else
+ printf("Couldn't unlink nsifaddr from ifp\n");
+ }
+ oia = ia;
+ if (oia == (ia = ns_ifaddr)) {
+ ns_ifaddr = ia->ia_next;
+ } else {
+ while (ia->ia_next && (ia->ia_next != oia)) {
+ ia = ia->ia_next;
+ }
+ if (ia->ia_next)
+ ia->ia_next = oia->ia_next;
+ else
+ printf("Didn't unlink nsifadr from list\n");
+ }
+ (void) m_free(dtom(oia));
+ if (0 == --ns_interfaces) {
+ /*
+ * We reset to virginity and start all over again
+ */
+ ns_thishost = ns_zerohost;
+ }
+ return (0);
+
+ case SIOCAIFADDR:
+ dstIsNew = 0; hostIsNew = 1;
+ if (ia->ia_addr.sns_family == AF_NS) {
+ if (ifra->ifra_addr.sns_len == 0) {
+ ifra->ifra_addr = ia->ia_addr;
+ hostIsNew = 0;
+ } else if (ns_neteq(ifra->ifra_addr.sns_addr,
+ ia->ia_addr.sns_addr))
+ hostIsNew = 0;
+ }
+ if ((ifp->if_flags & IFF_POINTOPOINT) &&
+ (ifra->ifra_dstaddr.sns_family == AF_NS)) {
+ if (hostIsNew == 0)
+ ns_ifscrub(ifp, ia);
+ ia->ia_dstaddr = ifra->ifra_dstaddr;
+ dstIsNew = 1;
+ }
+ if (ifra->ifra_addr.sns_family == AF_NS &&
+ (hostIsNew || dstIsNew))
+ error = ns_ifinit(ifp, ia, &ifra->ifra_addr, 0);
+ return (error);