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

Reply via email to