]> git.baikalelectronics.ru Git - kernel.git/commit
net: skb_segment() should preserve backpressure
authorToshiaki Makita <makita.toshiaki@lab.ntt.co.jp>
Mon, 27 Oct 2014 17:30:51 +0000 (10:30 -0700)
committerDavid S. Miller <davem@davemloft.net>
Wed, 29 Oct 2014 18:47:19 +0000 (14:47 -0400)
commitc5df89afdc9063e8712a4d343ebf4309b4c5efd0
tree9aa224539b3cd74aaed24a8a4195e9f5bc6fef61
parentdc63a8647519910d95e5ec6b913aaadbf86083b2
net: skb_segment() should preserve backpressure

This patch generalizes commit 50e53c488a20 ("tcp: GSO should be TSQ
friendly") to protocols using skb_set_owner_w()

TCP uses its own destructor (tcp_wfree) and needs a more complex scheme
as explained in commit ffb430f8feb4 ("tcp: gso: do not generate out of
order packets")

This allows UDP sockets using UFO to get proper backpressure,
thus avoiding qdisc drops and excessive cpu usage.

Here are performance test results (macvlan on vlan):

- Before
# netperf -t UDP_STREAM ...
Socket  Message  Elapsed      Messages
Size    Size     Time         Okay Errors   Throughput
bytes   bytes    secs            #      #   10^6bits/sec

212992   65507   60.00      144096 1224195    1258.56
212992           60.00          51              0.45

Average:        CPU     %user     %nice   %system   %iowait    %steal     %idle
Average:        all      0.23      0.00     25.26      0.08      0.00     74.43

- After
# netperf -t UDP_STREAM ...
Socket  Message  Elapsed      Messages
Size    Size     Time         Okay Errors   Throughput
bytes   bytes    secs            #      #   10^6bits/sec

212992   65507   60.00      109593      0     957.20
212992           60.00      109593            957.20

Average:        CPU     %user     %nice   %system   %iowait    %steal     %idle
Average:        all      0.18      0.00      8.38      0.02      0.00     91.43

[edumazet] Rewrote patch and changelog.

Signed-off-by: Toshiaki Makita <makita.toshiaki@lab.ntt.co.jp>
Signed-off-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/core/skbuff.c