From: 'Marcelo Ricardo Leitner' > Sent: 28 January 2016 20:56 > On Thu, Jan 28, 2016 at 05:30:24PM +0000, David Laight wrote: > > From: 'Marcelo Ricardo Leitner' > > > Sent: 28 January 2016 15:53 > > > On Thu, Jan 28, 2016 at 01:51:02PM +0000, David Laight wrote: ... > > > > With Nagle disabled (and it probably has to be since the data flow > > > > is unlikely to be 'command-response' or 'unidirectional bulk') > > > > it is currently almost impossible to get more than one chunk > > > > into an ethernet frame. > > > > > > > > Support for MSG_MORE would help. > > > > > > > > Given the current implementation you can get almost the required > > > > behaviour by turning nagle off and on repeatedly. > > > > > > That's pretty much expected, I think. Without Nagle, if bandwidth and > > > cwnd allow, segment will be sent. GSO by itself shouldn't cause a > > > buffering to protect from that. > > > > > > If something causes a bottleneck, tx may get queue up. Like if I do a > > > stress test in my system, generally receiver side is slower than sender, > > > so I end up having tx buffers pretty easily. It mimics bandwidth > > > restrictions. > > > > Imagine a using M2UA to connect local machines (one running mtp3, the other mtp2). > > Configure two linksets of 16 signalling links and perform a double-reflect > > loopback test. > > The SCTP connection won't ever saturate, so every msu ends up in its own > > ethernet packet. > > It is easy to generate 1000's of ethernet frames/sec on a single connection. > > > > (We do this with something not entirely quite like M2UA over TCP, > > even then it is very hard to get multiple message into a single > > ethernet frame.) > > > > Agreed, GSO won't help much in there without a corking feature like > MSG_MORE or that on/off switch on Nagle you mentioned. > > Thing about this (and also GRO) is on identifying how much can be spent > on waiting for the next chunk/packet without causing issues to the > application. Nagle is there and helps quite a lot, but timing-sensitive > applications will turn it off. Nagle is only any good for unidirectional data (think file transfer) and command-response (think telnet or rlogin), for anything else it generates 200ms+ delays. The SIGTRAN protocols (M3UA etc) are all specified to use SCTP and have no real relationship between the send and receive data. SCTP is being used to replace 64kb/s links so a few milliseconds of delay (1ms is 8 byte times) probably don't matter. The Nagle timeout is, however far too long - so has to be disabled. So never mind GSO to improve 'bulk' output, the big SCTP performance issue (as I see it) is the inability for a lot of workloads to ever get more than one small data chunk into an ethernet frame. Which other (application) protocols are using SCTP? It doesn't seem an appropriate protocol for bulk data. David -- To unsubscribe from this list: send the line "unsubscribe linux-sctp" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html