This might even solve my Kerberos V problem when IPv6 is enabled in the kernel. Regards, Phone: (250)387-8437 Cy Schubert Fax: (250)387-5766 Team Leader, Sun/DEC Team Internet: [EMAIL PROTECTED] Open Systems Group, ITSD, ISTA Province of BC In message <[EMAIL PROTECTED]>, Hajimu UMEMOTO writes: > ----Next_Part(Mon_May_29_19:35:22_2000_809)-- > Content-Type: Text/Plain; charset=us-ascii > Content-Transfer-Encoding: 7bit > > >>>>> On Sun, 28 May 2000 21:04:23 -0400 > >>>>> Will Andrews <[EMAIL PROTECTED]> said: > > > What would make ftp(1) think it has an IPv6 connection? > > andrews> I have no idea.. > > It seems ftp(1) think using IPv6. > > There is a bug in existing getaddrinfo(). getaddrinfo() returns IPv4 > address as IPv4 mapped IPv6 address in some case. It occures when: > > - INET6 is enabled in kernel > - host has A RR and AAAA RR > > IPv4 connection via mapped address is still IPv6 connection. In this > case, if ftp(1) doesn't have awareness of using mapped address, your > problem will occur. And, ftp(1) seems not aware about it. > > But, it seems ftp.FreeBSD.org does't have AAAA RR. So, I believe it > is not applicable to your case. And, actually I dont' see this > problem here. However, I have no idea without this case. So, I > attach the patch to solve getaddrinfo() problem. Please try it and I > would like to hear the result. > > > ----Next_Part(Mon_May_29_19:35:22_2000_809)-- > Content-Type: Text/Plain; charset=us-ascii > Content-Transfer-Encoding: 7bit > Content-Description: getaddrinfo-mapped-workaround.diff > Content-Disposition: attachment; > filename="getaddrinfo-mapped-workaround.diff" > > Index: lib/libc/net/getaddrinfo.c > diff -u lib/libc/net/getaddrinfo.c.orig lib/libc/net/getaddrinfo.c > --- lib/libc/net/getaddrinfo.c.orig Thu Apr 20 12:31:40 2000 > +++ lib/libc/net/getaddrinfo.c Mon Apr 24 21:41:24 2000 > @@ -148,6 +148,7 @@ > static int get_portmatch __P((const struct addrinfo *, const char *)); > static int get_port __P((struct addrinfo *, const char *, int)); > static const struct afd *find_afd __P((int)); > +static void unmappedaddr __P((struct addrinfo *)); > > static char *ai_errlist[] = { > "Success", > @@ -512,6 +513,7 @@ > */ > GET_CANONNAME(cur->ai_next, hp->h_name); > } > + unmappedaddr(cur->ai_next); > > while (cur && cur->ai_next) > cur = cur->ai_next; > @@ -903,4 +905,25 @@ > return afd; > } > return NULL; > +} > + > +static void > +unmappedaddr(struct addrinfo *res) > +{ > + struct sockaddr_in6 *sin6; > + struct sockaddr_in *sin; > + u_int32_t addr; > + int port; > + > + sin6 = (struct sockaddr_in6 *)res->ai_addr; > + if (IN6_IS_ADDR_V4MAPPED(&sin6->sin6_addr)) { > + sin = (struct sockaddr_in *)res->ai_addr; > + addr = *(u_int32_t *)&sin6->sin6_addr.s6_addr[12]; > + port = sin6->sin6_port; > + memset(res->ai_addr, 0, res->ai_addrlen); > + sin->sin_addr.s_addr = addr; > + sin->sin_port = port; > + sin->sin_family = res->ai_family = AF_INET; > + sin->sin_len = res->ai_addrlen = sizeof(struct sockaddr_in); > + } > } > > ----Next_Part(Mon_May_29_19:35:22_2000_809)-- > Content-Type: Text/Plain; charset=us-ascii > Content-Transfer-Encoding: 7bit > Content-Description: My Signature > Content-Disposition: attachment; filename=".signature-world" > > Hajimu UMEMOTO @ Internet Mutual Aid Society Yokohama, Japan > [EMAIL PROTECTED] [EMAIL PROTECTED] [EMAIL PROTECTED] > http://www.imasy.org/~ume/ > > ----Next_Part(Mon_May_29_19:35:22_2000_809)---- > > > To Unsubscribe: send mail to [EMAIL PROTECTED] > with "unsubscribe freebsd-stable" in the body of the message To Unsubscribe: send mail to [EMAIL PROTECTED] with "unsubscribe freebsd-current" in the body of the message
Re: ftp(1) breakage w/ passive mode?
Cy Schubert - ITSD Open Systems Group Mon, 29 May 2000 07:59:57 -0700
- ftp(1) breakage w/ passive mode? Will Andrews
- Re: ftp(1) breakage w/ passive ... Cy Schubert - ITSD Open Systems Group
- Re: ftp(1) breakage w/ pass... Will Andrews
- Re: ftp(1) breakage w/ ... 梅本 肇
- Re: ftp(1) breakage... itojun
- Re: ftp(1) breakage... Cy Schubert - ITSD Open Systems Group
- Re: ftp(1) breakage... Alexander Langer
- Re: ftp(1) bre... itojun
- Re: ftp(1)... Cy Schubert - ITSD Open Systems Group