diff options
author | Eric Dumazet <edumazet@google.com> | 2016-06-14 06:21:56 +0300 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2016-06-16 00:08:35 +0300 |
commit | a5a9f5346fb95c00d47e8b4648f6d5eada147cd4 (patch) | |
tree | 193c7e0eec88d43b63f92f29bec1868762315051 | |
parent | e7e424cdc4b2fcd7507b71d3a931708d11d5a61e (diff) | |
download | linux-a5a9f5346fb95c00d47e8b4648f6d5eada147cd4.tar.xz |
net_sched: sch_htb: defer skb freeing
Both htb_reset() and htb_destroy() can use __qdisc_reset_queue()
instead of __skb_queue_purge() to defer skb freeing of internal
queues.
Signed-off-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | net/sched/sch_htb.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/net/sched/sch_htb.c b/net/sched/sch_htb.c index 07dcd2933f01..a454605ab5cb 100644 --- a/net/sched/sch_htb.c +++ b/net/sched/sch_htb.c @@ -957,7 +957,7 @@ static void htb_reset(struct Qdisc *sch) } } qdisc_watchdog_cancel(&q->watchdog); - __skb_queue_purge(&q->direct_queue); + __qdisc_reset_queue(&q->direct_queue); sch->q.qlen = 0; sch->qstats.backlog = 0; memset(q->hlevel, 0, sizeof(q->hlevel)); @@ -1231,7 +1231,7 @@ static void htb_destroy(struct Qdisc *sch) htb_destroy_class(sch, cl); } qdisc_class_hash_destroy(&q->clhash); - __skb_queue_purge(&q->direct_queue); + __qdisc_reset_queue(&q->direct_queue); } static int htb_delete(struct Qdisc *sch, unsigned long arg) |