udp: do rmem bulk free even if the rx sk queue is empty
authorPaolo Abeni <pabeni@redhat.com>
Tue, 19 Sep 2017 10:11:43 +0000 (12:11 +0200)
committerDavid S. Miller <davem@davemloft.net>
Wed, 20 Sep 2017 21:28:52 +0000 (14:28 -0700)
commit0d4a6608f68c7532dcbfec2ea1150c9761767d03
tree26373be5bf2c3173f3eae9b0cbe69d5a083c1c0a
parent186b3c998c50fc241b51b905081c748455d16b4a
udp: do rmem bulk free even if the rx sk queue is empty

The commit 6b229cf77d68 ("udp: add batching to udp_rmem_release()")
reduced greatly the cacheline contention between the BH and the US
reader batching the rmem updates in most scenarios.

Such optimization is explicitly avoided if the US reader is faster
then BH processing.

My fault, I initially suggested this kind of behavior due to concerns
of possible regressions with small sk_rcvbuf values. Tests showed
such concerns are misplaced, so this commit relaxes the condition
for rmem bulk updates, obtaining small but measurable performance
gain in the scenario described above.

Signed-off-by: Paolo Abeni <pabeni@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/ipv4/udp.c