Merge branch 'inet-factorize-sk_wmem_alloc-updates'
authorDavid S. Miller <davem@davemloft.net>
Sun, 1 Apr 2018 18:08:21 +0000 (14:08 -0400)
committerDavid S. Miller <davem@davemloft.net>
Sun, 1 Apr 2018 18:08:21 +0000 (14:08 -0400)
commit16c3c91346961fdd733ad232311772795599be7f
tree253468761ee8e0f7a7cd97f21c24ef3c841529e7
parentc07255020551cadae8bf903f2c5e1fcbad731bac
parent1f4c6eb24029689a40dceae561e31ff6926d7f0d
Merge branch 'inet-factorize-sk_wmem_alloc-updates'

Eric Dumazet says:

====================
inet: factorize sk_wmem_alloc updates

While testing my inet defrag changes, I found that senders
could spend ~20% of cpu cycles in skb_set_owner_w() updating
sk->sk_wmem_alloc for every fragment they cook, competing
with TX completion of prior skbs possibly happening on another cpus.

One solution to this problem is to use alloc_skb() instead
of sock_wmalloc() and manually perform a single sk_wmem_alloc change.

This greatly increases speed for applications sending big UDP datagrams.
====================

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