Date: Fri, 16 Jan 2004 17:28:30 -0800 (PST) From: Kelly Yancey <kelly@nttmcl.com> To: net@freebsd.org Subject: Re: bge data corruption bug (was: 1168 octets payload and bad TCPchecksums) Message-ID: <20040116163017.G1217-100000@alicia.nttmcl.com> In-Reply-To: <20040113130721.U15761-102000@alicia.nttmcl.com>
next in thread | previous in thread | raw e-mail | index | archive | help
On Tue, 13 Jan 2004, Kelly Yancey wrote: > > On Fri, 2 Jan 2004, Kelly Yancey wrote: > > > > > We've got Broadcom BCM5701 cards configured for vlan tagging on a > > FreeBSD 4.7 based router; a vlan switch then terminates the trunked > > segment and splits it into separate physical subnets. It turns out that > > hosts on those segments cannot receive TCP packets with precisely 1168 > > octets of payload (ethernet frame size 1222 octets) as the checksum is > > always incorrect. We've manually backported all of the bge driver updates > > from 4-stable, but to no avail. > > What is particularly odd is that the checksums are always wrong by the > > same amount: 0xAC48 (the dump below only shows retries of the same > > packet, but the difference is the same even for other packets). > > Furthermore, it appears only TCP packets with 1168 octets of data are > > affected. I cannot easily create an environment without the vlans to > > determine whether or not tagging is related. Note also, that the IP > > checksum is correct. > > > > First, once slight clarification to my original posting: the received > from, after vlan untagging is 1222 octets; the sent frame includes a tag > so it is 1226 octets. > > Anyway, it appears that the cause of the bad checksums are that the last > dword of the transmitted frame is getting corrupted in hardware. > [ .. snip .. ] > So far, we have only been able to reproduce the problem with TCP packets > with 1168 octets of payload, using vlan tagging on the bge interface. [ .. snip .. ] Final update, just for the record: it turns out that, after adjusting for the difference in header sizes, the bug is easily reproduceable using ping with 1177 to 1180 bytes of payload. So, it isn't just TCP, and it isn't just 1222 byte (1126 with vlan tag) ethernet frames. It is a definate 4-byte window of 1219 to 1222 byte packets. Furthermore, the corruption is caused by the hardware apparently copying the dword 3rd from the end of the packet into the last dword of the frame. You can see this in the dumps in my previous posting, but using ping makes the problem really stand out. For example, the server sends a ICMP echo request which ends with: # tcpdump -Xx -s 4000 -pni vlan9 icmp [ snip ] 0x04a0 8485 8687 8889 8a8b 8c8d 8e8f 9091 9293 ................ 0x04b0 9495 9697 9899 9a9b ........ Then the client receives: # tcpdump -Xx -s 4000 -pni an0 icmp [ snip ] 0x04a0 8485 8687 8889 8a8b 8c8d 8e8f 9091 9293 ................ 0x04b0 9495 9697 9091 9293 ........ I've verified this with different clients, running both FreeBSD and Windows, and using different NICs on the client side. Swapping out the bge interface for one supported by the sk or em driver solves the problem. The workaround that we have found for the bge interface is to simply set the LINK0 flag on the vlan interfaces. I guess something about letting the hardware add the vlan tag keeps it from mangling our packets. Which means that this bug only affects -stable as sam's 1.44 delta avoids the issue on FreeBSD 5.0 and higher. In any event, we have our solution; if anyone else out there is using a bge card as a vlan parent interface on a 4.x box, consider yourself warned: enable LINK0 or face seemingly random data corruption. Kelly -- Kelly Yancey - kbyanc@{posi.net,FreeBSD.org} - kelly@nttmcl.com
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20040116163017.G1217-100000>