Kelly Yancey wrote: > It doesn't matter. It isn't just DNS lookups, mountd fails to run too > because it cannot connect to portmap via localhost. Oddly, in both cases > sendto() is returning with errno = 49 (EADDRNOTAVAIL). I've tracked it down > to this code in sys/netinet/ip_output.c: > > /* 127/8 must not appear on wire - RFC1122. */ > if ((ntohl(ip->ip_dst.s_addr) >> IN_CLASSA_NSHIFT) == IN_LOOPBACKNET || > (ntohl(ip->ip_src.s_addr) >> IN_CLASSA_NSHIFT) == IN_LOOPBACKNET) { > if ((ifp->if_flags & IFF_LOOPBACK) == 0) { > ipstat.ips_badaddr++; > error = EADDRNOTAVAIL; > goto bad; > } > } > > Which was last modified in revision 1.150 back in February. However, I > still don't see how adding an extra counter to the sockbuf could possibly > change the set of events required to get to this code, but it is certainly > what is causing EADDRNOTAVAIL to be returned. Needless to say, I'm still > researching it.
Pretty clear, I should think: IF the source address is a loopback address OR the destination address is a loopback address THEN IF the interface does not have the IFF_LOOBACK flag return EADDRNOTAVAIL ...pretty clearly, the new loopback interface doe not set the flag IFF_LOOPBACK on the interface, as it is supposed to do. -- Terry To Unsubscribe: send mail to [EMAIL PROTECTED] with "unsubscribe freebsd-current" in the body of the message