From: Daniel Axtens Date: Thu, 1 Mar 2018 06:13:38 +0000 (+1100) Subject: net: sched: tbf: handle GSO_BY_FRAGS case in enqueue X-Git-Tag: v4.16-rc5~37^2~5^2~2 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=ee78bbef8d63202ca0f2485aecf30b8c2b0088cc;p=users%2Fdwmw2%2Flinux.git net: sched: tbf: handle GSO_BY_FRAGS case in enqueue tbf_enqueue() checks the size of a packet before enqueuing it. However, the GSO size check does not consider the GSO_BY_FRAGS case, and so will drop GSO SCTP packets, causing a massive drop in throughput. Use skb_gso_validate_mac_len() instead, as it does consider that case. Signed-off-by: Daniel Axtens Reviewed-by: Marcelo Ricardo Leitner Signed-off-by: David S. Miller --- diff --git a/net/sched/sch_tbf.c b/net/sched/sch_tbf.c index 229172d509cc5..03225a8df9730 100644 --- a/net/sched/sch_tbf.c +++ b/net/sched/sch_tbf.c @@ -188,7 +188,8 @@ static int tbf_enqueue(struct sk_buff *skb, struct Qdisc *sch, int ret; if (qdisc_pkt_len(skb) > q->max_size) { - if (skb_is_gso(skb) && skb_gso_mac_seglen(skb) <= q->max_size) + if (skb_is_gso(skb) && + skb_gso_validate_mac_len(skb, q->max_size)) return tbf_segment(skb, sch, to_free); return qdisc_drop(skb, sch, to_free); }