diff options
author | Jarek Poplawski <jarkao2@gmail.com> | 2008-11-03 02:52:50 -0800 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-11-03 02:52:50 -0800 |
commit | 67305ebc992abf2121fb2149fd8a707cd7cfcbd2 (patch) | |
tree | 4d6972424550db5ff5f42290f81c29a31e1fda49 | |
parent | 5799de0b12c773874282444052da401989075df6 (diff) | |
download | lwn-67305ebc992abf2121fb2149fd8a707cd7cfcbd2.tar.gz lwn-67305ebc992abf2121fb2149fd8a707cd7cfcbd2.zip |
pkt_sched: sch_generic: Kfree gso_skb in qdisc_reset()
Since gso_skb is re-used for qdisc_peek_dequeued(), and this skb is
counted in the qdisc->q.qlen, it has to be kfreed during qdisc_reset()
when qlen is zeroed.
With help from David S. Miller <davem@davemloft.net>
Signed-off-by: Jarek Poplawski <jarkao2@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | net/sched/sch_generic.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/net/sched/sch_generic.c b/net/sched/sch_generic.c index 318c9f656e8e..1192da229835 100644 --- a/net/sched/sch_generic.c +++ b/net/sched/sch_generic.c @@ -542,6 +542,9 @@ void qdisc_reset(struct Qdisc *qdisc) if (ops->reset) ops->reset(qdisc); + + kfree_skb(qdisc->gso_skb); + qdisc->gso_skb = NULL; } EXPORT_SYMBOL(qdisc_reset); |