summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEric Dumazet <edumazet@google.com>2016-06-14 05:21:57 +0200
committerDavid S. Miller <davem@davemloft.net>2016-06-15 23:08:35 +0200
commit2f08a9a16288b60df3ddfe97c965427ce0163297 (patch)
treebb271fd65501875aa42fa7f70c1af181cfd3b869
parentnet_sched: sch_htb: defer skb freeing (diff)
downloadlinux-2f08a9a16288b60df3ddfe97c965427ce0163297.tar.xz
linux-2f08a9a16288b60df3ddfe97c965427ce0163297.zip
net_sched: sch_netem: defer skb freeing
rtnl_kfree_skbs() can be used in tfifo_reset() It would be nice if we could iterate through rb tree instead of removing one skb at a time, and build a single skb chain. But this is left for a future patch. Signed-off-by: Eric Dumazet <edumazet@google.com> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--net/sched/sch_netem.c4
1 files changed, 1 insertions, 3 deletions
diff --git a/net/sched/sch_netem.c b/net/sched/sch_netem.c
index 876df13c745a..e271967439bf 100644
--- a/net/sched/sch_netem.c
+++ b/net/sched/sch_netem.c
@@ -368,9 +368,7 @@ static void tfifo_reset(struct Qdisc *sch)
struct sk_buff *skb = netem_rb_to_skb(p);
rb_erase(p, &q->t_root);
- skb->next = NULL;
- skb->prev = NULL;
- kfree_skb(skb);
+ rtnl_kfree_skbs(skb, skb);
}
}