On Tue, 17 Mar 2009, Dave Boutcher wrote: > Eric, based on your inability to recreate this, I tried on some other > hardware I had lying around that has an AMD chipset built-in NIC. > I could not recreate the problem on that hardware. I'm starting to > think this is an e1000 problem. In both the e1000 and e1000e > drivers they do the following logic: > > /* clear the old settings from the multicast hash table */ > > for (i = 0; i < mta_reg_count; i++) { > E1000_WRITE_REG_ARRAY(hw, MTA, i, 0); > E1000_WRITE_FLUSH(); > } > > /* load any remaining addresses into the hash table */ > > for (; mc_ptr; mc_ptr = mc_ptr->next) { > hash_value = e1000_hash_mc_addr(hw, mc_ptr->da_addr); > e1000_mta_set(hw, hash_value); > } > > There's clearly a window where the NIC doesn't have the multicast > addresses loaded. This may just be broken-as-designed. If anyone > else happens to have some e1000 hardware and wants to see if you > can recreate this, I'd be curious. > > Some other notes just FYI... > > - RcvbufErrors in /proc/net/snmp doesn't get incremented when this happens > - there are no messages in dmesg > - frames get dropped when the program calls exit() and all the sockets > get closed > (and multicast joins dropped) as well as when the ADD_MEMBERSHIPs happen > - The problem happens even when adding a sleep(1) in between each of the > ADD_MEMBERSHIP calls.
Interesting, this code has been there for eons (and probably this behavior) but that doesn't mean its not a problem. We are in the process of figuring out if there are any hardware corner cases to changing this code (particularly in e1000) Initial thoughts are: 1) kcalloc an array that we then populate with the hash functions, and then program every location only once (never flush) 2) only program a single hash value each time a multicast is added (bad because we can't tell the difference in the list since the last time the OS gave us the list) It really seems like this should be fixable, and I agree that the driver behavior is far from optimal, however well entrenched. Jesse ------------------------------------------------------------------------------ Apps built with the Adobe(R) Flex(R) framework and Flex Builder(TM) are powering Web 2.0 with engaging, cross-platform capabilities. Quickly and easily build your RIAs with Flex Builder, the Eclipse(TM)based development software that enables intelligent coding and step-through debugging. Download the free 60 day trial. http://p.sf.net/sfu/www-adobe-com _______________________________________________ E1000-devel mailing list E1000-devel@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/e1000-devel