Date: Fri, 2 Jan 2009 14:15:44 -0800 From: "Li, Qing" <qing.li@bluecoat.com> To: =?iso-8859-1?Q?Michael_T=FCxen?= <Michael.Tuexen@lurchi.franken.de> Cc: qingli@freebsd.org, current@freebsd.org, FreeBSD Net <freebsd-net@freebsd.org> Subject: RE: SCTP related issue with recent ARP changes? Message-ID: <B583FBF374231F4A89607B4D08578A4302B92332@bcs-mail03.internal.cacheflow.com> In-Reply-To: <B583FBF374231F4A89607B4D08578A431442FE@bcs-mail03.internal.cacheflow.com> References: <A3B60541-1902-421D-A57B-C554B93AF912@lurchi.franken.de> <B583FBF374231F4A89607B4D08578A431442FE@bcs-mail03.internal.cacheflow.com>
next in thread | previous in thread | raw e-mail | index | archive | help
Hi Michael, The SCTP problem you were having was attributed to the arp-v2 changes. The reason TCP and UDP works well is because the TCP and UDP modules does not supply a route entry when calling ip_output(). Consequently in ip_output() the destination (sockaddr) was reinitialized = and the sin_port field is 0. The destination sockaddr supplied in the route entry from the SCTP module has the actual port value in it. The new L2 search was (initially) written as a generic function. So the L3 address comparison was performed using bcmp() of sockaddr_len bytes. The L2 entry was created with a sockaddr object that includes the port value, however, on ARP input the port value does not apply. The mismatch in port value causes the ARP lookup to fail and the SCTP connection never complete its negotiation. Please apply the patch for IPv4 in my home directory at http://people.freebsd.org/~qingli/in.c.diff I did the basic testing using the programs you gave me and now the client connects successful and completes the transfer. I also verified the packets in wireshark trace. Please let me know if this patch fixes your SCTP problems. Thank you for your help. -- Qing > -----Original Message----- > From: owner-freebsd-current@freebsd.org [mailto:owner-freebsd- > current@freebsd.org] On Behalf Of Li, Qing > Sent: Thursday, January 01, 2009 12:17 PM > To: Michael T=FCxen; FreeBSD Net > Cc: qingli@freebsd.org; current@freebsd.org > Subject: RE: SCTP related issue with recent ARP changes? >=20 >=20 > Hi Michael, >=20 > Your problem could be related to the recent ARP changes. > I will investigate further to confirm. >=20 > Thanks, >=20 > -- Qing >=20 >=20 > -----Original Message----- > From: owner-freebsd-net@freebsd.org on behalf of Michael T=FCxen > Sent: Thu 1/1/2009 8:59 AM > To: FreeBSD Net > Subject: SCTP related issue with recent ARP changes? >=20 > Dear all, >=20 > I'm running the current CVS version of FreeBSD 8 in a virtual > machine using VMWare 2.0.1 on a Mac (not sure if this is relevant) > and bridged networking having an em interface on the virtual machine. > I'm using a similar setup with older FreeBSD machines and they are > running fine. >=20 > Loopback communication based on UDP, TCP, SCTP or ICMP works fine. >=20 > Communicating with other hosts using UDP, TCP or ICMP works fine. >=20 > Communicating with other hosts using SCTP does not work. > The SCTP stack calls ip_output() and an ARP request for the > correct destination IP address is send out. A corresponding > ARP reply is visible in Wireshark (running on the FreeBSD 8 box) > and looks good. However, the corresponding SCTP packet it never > sent out. I'm not sure, but this might be related to the > recent ARP changes. Is there anything required from the > transport layer to be done when calling ip_output() that > was not required before? >=20 > Best regards > Michael >=20
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?B583FBF374231F4A89607B4D08578A4302B92332>