]> git.baikalelectronics.ru Git - kernel.git/commit
Merge branch 'tcp-lockless-listener'
authorDavid S. Miller <davem@davemloft.net>
Sat, 3 Oct 2015 11:32:52 +0000 (04:32 -0700)
committerDavid S. Miller <davem@davemloft.net>
Sat, 3 Oct 2015 11:32:52 +0000 (04:32 -0700)
commit95fa2090db9c5148bf5c8dd1047bab80645892cb
tree0caf05649d27830ba0f9548704abbb1ec4b5bb91
parent23cc6b0f7d54ec643e7a747bc4f30503c7e347c7
parentd3095cf4659147df2a95b543ab987c9c0df655d5
Merge branch 'tcp-lockless-listener'

Eric Dumazet says:

====================
tcp/dccp: lockless listener

TCP listener refactoring : this is becoming interesting !

This patch series takes the steps to use normal TCP/DCCP ehash
table to store SYN_RECV requests, instead of the private per-listener
hash table we had until now.

SYNACK skb are now attached to their syn_recv request socket,
so that we no longer heavily modify listener sk_wmem_alloc.

listener lock is no longer held in fast path, including
SYNCOOKIE mode.

During my tests, my server was able to process 3,500,000
SYN packets per second on one listener and still had available
cpu cycles.

That is about 2 to 3 order of magnitude what we had with older kernels.

This effort started two years ago and I am pleased to reach expectations.

We'll probably extend SO_REUSEPORT to add proper cpu/numa affinities,
so that heavy duty TCP servers can get proper siloing thanks to multi-queues
NIC.
====================

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