Skip to content

Commit 432c856

Browse files
Toshiaki Makitadavem330
authored andcommitted
net: skb_segment() should preserve backpressure
This patch generalizes commit d6a4a10 ("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 6ff50cd ("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>
1 parent 45b679c commit 432c856

File tree

1 file changed

+10
-0
lines changed

1 file changed

+10
-0
lines changed

net/core/skbuff.c

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -3099,6 +3099,16 @@ struct sk_buff *skb_segment(struct sk_buff *head_skb,
30993099
* (see validate_xmit_skb_list() for example)
31003100
*/
31013101
segs->prev = tail;
3102+
3103+
/* Following permits correct backpressure, for protocols
3104+
* using skb_set_owner_w().
3105+
* Idea is to tranfert ownership from head_skb to last segment.
3106+
*/
3107+
if (head_skb->destructor == sock_wfree) {
3108+
swap(tail->truesize, head_skb->truesize);
3109+
swap(tail->destructor, head_skb->destructor);
3110+
swap(tail->sk, head_skb->sk);
3111+
}
31023112
return segs;
31033113

31043114
err:

0 commit comments

Comments
 (0)