On Tue, 7 Mar 2006 00:34:38 +0200 "Michael S. Tsirkin" <[EMAIL PROTECTED]> wrote:
> Hello, Dave! > As you might know, the TSO patches merged into mainline kernel > since 2.6.11 have hurt performance for the simple (non-TSO) > high-speed netdevice that is IPoIB driver. > > This was discussed at length here > http://openib.org/pipermail/openib-general/2005-October/012271.html > > I'm trying to figure out what can be done to improve the situation. > In partucular, I'm looking at the Super TSO patch > http://oss.sgi.com/archives/netdev/2005-05/msg00889.html > > merged into mainline here > > http://www.kernel.org/git/?p=linux/kernel/git/torvalds/linux-2.6.git;a=commit;h=314324121f9b94b2ca657a494cf2b9cb0e4a28cc > > There, you said: > > When we do ucopy receive (ie. copying directly to userspace > during tcp input processing) we attempt to delay the ACK > until cleanup_rbuf() is invoked. Most of the time this > technique works very well, and we emit one ACK advertising > the largest window. > > But this explodes if the ucopy prequeue is large enough. > When the receiver is cpu limited and TSO frames are large, > the receiver is inundated with ucopy processing, such that > the ACK comes out very late. Often, this is so late that > by the time the sender gets the ACK the window has emptied > too much to be kept full by the sender. > > The existing TSO code mostly avoided this by keeping the > TSO packets no larger than 1/8 of the available window. > But with the new code we can get much larger TSO frames. > > So I'm trying to get a handle on it: could a solution be to simply > look at the frame size, and call tcp_send_delayed_ack from > if the frame size is no larger than 1/8? > > Does this make sense? > > Thanks, > > More likely you are getting hit by the fact that TSO prevents the congestion window from increasing properly. This was fixed in 2.6.15 (around mid of Nov 2005). - To unsubscribe from this list: send the line "unsubscribe netdev" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html