net: sk_add_backlog() take rmem_alloc into account
authorEric Dumazet <eric.dumazet@gmail.com>
Tue, 27 Apr 2010 22:13:20 +0000 (15:13 -0700)
committerDavid S. Miller <davem@davemloft.net>
Tue, 27 Apr 2010 22:13:20 +0000 (15:13 -0700)
commitc377411f2494a931ff7facdbb3a6839b1266bcf6
tree6846cdcec913f50839e3916856f78f7e059ff5fb
parent6e7676c1a76aed6e957611d8d7a9e5592e23aeba
net: sk_add_backlog() take rmem_alloc into account

Current socket backlog limit is not enough to really stop DDOS attacks,
because user thread spend many time to process a full backlog each
round, and user might crazy spin on socket lock.

We should add backlog size and receive_queue size (aka rmem_alloc) to
pace writers, and let user run without being slow down too much.

Introduce a sk_rcvqueues_full() helper, to avoid taking socket lock in
stress situations.

Under huge stress from a multiqueue/RPS enabled NIC, a single flow udp
receiver can now process ~200.000 pps (instead of ~100 pps before the
patch) on a 8 core machine.

Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/net/sock.h
net/core/sock.c
net/ipv4/udp.c
net/ipv6/udp.c
net/sctp/socket.c