Merge branch 'netem-fix-further-issues-with-packet-corruption'

Jakub Kicinski says:

====================
net: netem: fix further issues with packet corruption

This set is fixing two more issues with the netem packet corruption.

First patch (which was previously posted) avoids NULL pointer dereference
if the first frame gets freed due to allocation or checksum failure.
v2 improves the clarity of the code a little as requested by Cong.

Second patch ensures we don't return SUCCESS if the frame was in fact
dropped. Thanks to this commit message for patch 1 no longer needs the
"this will still break with a single-frame failure" disclaimer.
====================

Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
David S. Miller 2019-10-19 12:12:36 -07:00
commit 708738376c
1 changed files with 8 additions and 3 deletions

View File

@ -509,6 +509,7 @@ static int netem_enqueue(struct sk_buff *skb, struct Qdisc *sch,
if (skb->ip_summed == CHECKSUM_PARTIAL && if (skb->ip_summed == CHECKSUM_PARTIAL &&
skb_checksum_help(skb)) { skb_checksum_help(skb)) {
qdisc_drop(skb, sch, to_free); qdisc_drop(skb, sch, to_free);
skb = NULL;
goto finish_segs; goto finish_segs;
} }
@ -593,9 +594,10 @@ static int netem_enqueue(struct sk_buff *skb, struct Qdisc *sch,
finish_segs: finish_segs:
if (segs) { if (segs) {
unsigned int len, last_len; unsigned int len, last_len;
int nb = 0; int nb;
len = skb->len; len = skb ? skb->len : 0;
nb = skb ? 1 : 0;
while (segs) { while (segs) {
skb2 = segs->next; skb2 = segs->next;
@ -612,7 +614,10 @@ static int netem_enqueue(struct sk_buff *skb, struct Qdisc *sch,
} }
segs = skb2; segs = skb2;
} }
qdisc_tree_reduce_backlog(sch, -nb, prev_len - len); /* Parent qdiscs accounted for 1 skb of size @prev_len */
qdisc_tree_reduce_backlog(sch, -(nb - 1), -(len - prev_len));
} else if (!skb) {
return NET_XMIT_DROP;
} }
return NET_XMIT_SUCCESS; return NET_XMIT_SUCCESS;
} }