OSDN Git Service

Merge branch 'tcp-take-a-bit-more-care-of-backlog-stress'
authorDavid S. Miller <davem@davemloft.net>
Fri, 30 Nov 2018 21:26:54 +0000 (13:26 -0800)
committerDavid S. Miller <davem@davemloft.net>
Fri, 30 Nov 2018 21:26:54 +0000 (13:26 -0800)
commit2f69555315ad7dc1ac37366b2ac2429e2d24d444
tree3b70704dbf9f7cf27ec16d9321f7c1956b81c3a5
parentb0e3f1bdf9e7140fd1151af575f468b5827a61e1
parent4f693b55c3d2d2239b8a0094b518a1e533cf75d5
Merge branch 'tcp-take-a-bit-more-care-of-backlog-stress'

Eric Dumazet says:

====================
tcp: take a bit more care of backlog stress

While working on the SACK compression issue Jean-Louis Dupond
reported, we found that his linux box was suffering very hard
from tail drops on the socket backlog queue.

First patch hints the compiler about sack flows being the norm.

Second patch changes non-sack code in preparation of the ack
compression.

Third patch fixes tcp_space() to take backlog into account.

Fourth patch is attempting coalescing when a new packet must
be added to the backlog queue. Cooking bigger skbs helps
to keep backlog list smaller and speeds its handling when
user thread finally releases the socket lock.

v3: Neal/Yuchung feedback addressed :
     Do not aggregate if any skb has URG bit set.
     Do not aggregate if the skbs have different ECE/CWR bits

v2: added feedback from Neal : tcp: take care of compressed acks in tcp_add_reno_sack()
    added : tcp: hint compiler about sack flows
added : tcp: make tcp_space() aware of socket backlog
====================

Signed-off-by: David S. Miller <davem@davemloft.net>