Commit 86bd446b authored by Vlad Buslov's avatar Vlad Buslov Committed by David S. Miller

net: sched: rename qdisc_destroy() to qdisc_put()

Current implementation of qdisc_destroy() decrements Qdisc reference
counter and only actually destroy Qdisc if reference counter value reached
zero. Rename qdisc_destroy() to qdisc_put() in order for it to better
describe the way in which this function currently implemented and used.

Extract code that deallocates Qdisc into new private qdisc_destroy()
function. It is intended to be shared between regular qdisc_put() and its
unlocked version that is introduced in next patch in this series.
Signed-off-by: default avatarVlad Buslov <vladbu@mellanox.com>
Acked-by: default avatarJiri Pirko <jiri@mellanox.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 6f99528e
...@@ -554,7 +554,7 @@ void dev_deactivate_many(struct list_head *head); ...@@ -554,7 +554,7 @@ void dev_deactivate_many(struct list_head *head);
struct Qdisc *dev_graft_qdisc(struct netdev_queue *dev_queue, struct Qdisc *dev_graft_qdisc(struct netdev_queue *dev_queue,
struct Qdisc *qdisc); struct Qdisc *qdisc);
void qdisc_reset(struct Qdisc *qdisc); void qdisc_reset(struct Qdisc *qdisc);
void qdisc_destroy(struct Qdisc *qdisc); void qdisc_put(struct Qdisc *qdisc);
void qdisc_tree_reduce_backlog(struct Qdisc *qdisc, unsigned int n, void qdisc_tree_reduce_backlog(struct Qdisc *qdisc, unsigned int n,
unsigned int len); unsigned int len);
struct Qdisc *qdisc_alloc(struct netdev_queue *dev_queue, struct Qdisc *qdisc_alloc(struct netdev_queue *dev_queue,
......
...@@ -920,7 +920,7 @@ static void notify_and_destroy(struct net *net, struct sk_buff *skb, ...@@ -920,7 +920,7 @@ static void notify_and_destroy(struct net *net, struct sk_buff *skb,
qdisc_notify(net, skb, n, clid, old, new); qdisc_notify(net, skb, n, clid, old, new);
if (old) if (old)
qdisc_destroy(old); qdisc_put(old);
} }
/* Graft qdisc "new" to class "classid" of qdisc "parent" or /* Graft qdisc "new" to class "classid" of qdisc "parent" or
...@@ -973,7 +973,7 @@ static int qdisc_graft(struct net_device *dev, struct Qdisc *parent, ...@@ -973,7 +973,7 @@ static int qdisc_graft(struct net_device *dev, struct Qdisc *parent,
qdisc_refcount_inc(new); qdisc_refcount_inc(new);
if (!ingress) if (!ingress)
qdisc_destroy(old); qdisc_put(old);
} }
skip: skip:
...@@ -1561,7 +1561,7 @@ static int tc_modify_qdisc(struct sk_buff *skb, struct nlmsghdr *n, ...@@ -1561,7 +1561,7 @@ static int tc_modify_qdisc(struct sk_buff *skb, struct nlmsghdr *n,
err = qdisc_graft(dev, p, skb, n, clid, q, NULL, extack); err = qdisc_graft(dev, p, skb, n, clid, q, NULL, extack);
if (err) { if (err) {
if (q) if (q)
qdisc_destroy(q); qdisc_put(q);
return err; return err;
} }
......
...@@ -150,7 +150,7 @@ static void atm_tc_put(struct Qdisc *sch, unsigned long cl) ...@@ -150,7 +150,7 @@ static void atm_tc_put(struct Qdisc *sch, unsigned long cl)
pr_debug("atm_tc_put: destroying\n"); pr_debug("atm_tc_put: destroying\n");
list_del_init(&flow->list); list_del_init(&flow->list);
pr_debug("atm_tc_put: qdisc %p\n", flow->q); pr_debug("atm_tc_put: qdisc %p\n", flow->q);
qdisc_destroy(flow->q); qdisc_put(flow->q);
tcf_block_put(flow->block); tcf_block_put(flow->block);
if (flow->sock) { if (flow->sock) {
pr_debug("atm_tc_put: f_count %ld\n", pr_debug("atm_tc_put: f_count %ld\n",
......
...@@ -1418,7 +1418,7 @@ static void cbq_destroy_class(struct Qdisc *sch, struct cbq_class *cl) ...@@ -1418,7 +1418,7 @@ static void cbq_destroy_class(struct Qdisc *sch, struct cbq_class *cl)
WARN_ON(cl->filters); WARN_ON(cl->filters);
tcf_block_put(cl->block); tcf_block_put(cl->block);
qdisc_destroy(cl->q); qdisc_put(cl->q);
qdisc_put_rtab(cl->R_tab); qdisc_put_rtab(cl->R_tab);
gen_kill_estimator(&cl->rate_est); gen_kill_estimator(&cl->rate_est);
if (cl != &q->link) if (cl != &q->link)
......
...@@ -379,7 +379,7 @@ static void cbs_destroy(struct Qdisc *sch) ...@@ -379,7 +379,7 @@ static void cbs_destroy(struct Qdisc *sch)
cbs_disable_offload(dev, q); cbs_disable_offload(dev, q);
if (q->qdisc) if (q->qdisc)
qdisc_destroy(q->qdisc); qdisc_put(q->qdisc);
} }
static int cbs_dump(struct Qdisc *sch, struct sk_buff *skb) static int cbs_dump(struct Qdisc *sch, struct sk_buff *skb)
......
...@@ -134,7 +134,7 @@ static int drr_change_class(struct Qdisc *sch, u32 classid, u32 parentid, ...@@ -134,7 +134,7 @@ static int drr_change_class(struct Qdisc *sch, u32 classid, u32 parentid,
tca[TCA_RATE]); tca[TCA_RATE]);
if (err) { if (err) {
NL_SET_ERR_MSG(extack, "Failed to replace estimator"); NL_SET_ERR_MSG(extack, "Failed to replace estimator");
qdisc_destroy(cl->qdisc); qdisc_put(cl->qdisc);
kfree(cl); kfree(cl);
return err; return err;
} }
...@@ -153,7 +153,7 @@ static int drr_change_class(struct Qdisc *sch, u32 classid, u32 parentid, ...@@ -153,7 +153,7 @@ static int drr_change_class(struct Qdisc *sch, u32 classid, u32 parentid,
static void drr_destroy_class(struct Qdisc *sch, struct drr_class *cl) static void drr_destroy_class(struct Qdisc *sch, struct drr_class *cl)
{ {
gen_kill_estimator(&cl->rate_est); gen_kill_estimator(&cl->rate_est);
qdisc_destroy(cl->qdisc); qdisc_put(cl->qdisc);
kfree(cl); kfree(cl);
} }
......
...@@ -412,7 +412,7 @@ static void dsmark_destroy(struct Qdisc *sch) ...@@ -412,7 +412,7 @@ static void dsmark_destroy(struct Qdisc *sch)
pr_debug("%s(sch %p,[qdisc %p])\n", __func__, sch, p); pr_debug("%s(sch %p,[qdisc %p])\n", __func__, sch, p);
tcf_block_put(p->block); tcf_block_put(p->block);
qdisc_destroy(p->q); qdisc_put(p->q);
if (p->mv != p->embedded) if (p->mv != p->embedded)
kfree(p->mv); kfree(p->mv);
} }
......
...@@ -177,7 +177,7 @@ struct Qdisc *fifo_create_dflt(struct Qdisc *sch, struct Qdisc_ops *ops, ...@@ -177,7 +177,7 @@ struct Qdisc *fifo_create_dflt(struct Qdisc *sch, struct Qdisc_ops *ops,
if (q) { if (q) {
err = fifo_set_limit(q, limit); err = fifo_set_limit(q, limit);
if (err < 0) { if (err < 0) {
qdisc_destroy(q); qdisc_put(q);
q = NULL; q = NULL;
} }
} }
......
...@@ -901,7 +901,7 @@ struct Qdisc *qdisc_create_dflt(struct netdev_queue *dev_queue, ...@@ -901,7 +901,7 @@ struct Qdisc *qdisc_create_dflt(struct netdev_queue *dev_queue,
if (!ops->init || ops->init(sch, NULL, extack) == 0) if (!ops->init || ops->init(sch, NULL, extack) == 0)
return sch; return sch;
qdisc_destroy(sch); qdisc_put(sch);
return NULL; return NULL;
} }
EXPORT_SYMBOL(qdisc_create_dflt); EXPORT_SYMBOL(qdisc_create_dflt);
...@@ -941,15 +941,11 @@ void qdisc_free(struct Qdisc *qdisc) ...@@ -941,15 +941,11 @@ void qdisc_free(struct Qdisc *qdisc)
kfree((char *) qdisc - qdisc->padded); kfree((char *) qdisc - qdisc->padded);
} }
void qdisc_destroy(struct Qdisc *qdisc) static void qdisc_destroy(struct Qdisc *qdisc)
{ {
const struct Qdisc_ops *ops = qdisc->ops; const struct Qdisc_ops *ops = qdisc->ops;
struct sk_buff *skb, *tmp; struct sk_buff *skb, *tmp;
if (qdisc->flags & TCQ_F_BUILTIN ||
!refcount_dec_and_test(&qdisc->refcnt))
return;
#ifdef CONFIG_NET_SCHED #ifdef CONFIG_NET_SCHED
qdisc_hash_del(qdisc); qdisc_hash_del(qdisc);
...@@ -976,7 +972,16 @@ void qdisc_destroy(struct Qdisc *qdisc) ...@@ -976,7 +972,16 @@ void qdisc_destroy(struct Qdisc *qdisc)
qdisc_free(qdisc); qdisc_free(qdisc);
} }
EXPORT_SYMBOL(qdisc_destroy);
void qdisc_put(struct Qdisc *qdisc)
{
if (qdisc->flags & TCQ_F_BUILTIN ||
!refcount_dec_and_test(&qdisc->refcnt))
return;
qdisc_destroy(qdisc);
}
EXPORT_SYMBOL(qdisc_put);
/* Attach toplevel qdisc to device queue. */ /* Attach toplevel qdisc to device queue. */
struct Qdisc *dev_graft_qdisc(struct netdev_queue *dev_queue, struct Qdisc *dev_graft_qdisc(struct netdev_queue *dev_queue,
...@@ -1270,7 +1275,7 @@ static void shutdown_scheduler_queue(struct net_device *dev, ...@@ -1270,7 +1275,7 @@ static void shutdown_scheduler_queue(struct net_device *dev,
rcu_assign_pointer(dev_queue->qdisc, qdisc_default); rcu_assign_pointer(dev_queue->qdisc, qdisc_default);
dev_queue->qdisc_sleeping = qdisc_default; dev_queue->qdisc_sleeping = qdisc_default;
qdisc_destroy(qdisc); qdisc_put(qdisc);
} }
} }
...@@ -1279,7 +1284,7 @@ void dev_shutdown(struct net_device *dev) ...@@ -1279,7 +1284,7 @@ void dev_shutdown(struct net_device *dev)
netdev_for_each_tx_queue(dev, shutdown_scheduler_queue, &noop_qdisc); netdev_for_each_tx_queue(dev, shutdown_scheduler_queue, &noop_qdisc);
if (dev_ingress_queue(dev)) if (dev_ingress_queue(dev))
shutdown_scheduler_queue(dev, dev_ingress_queue(dev), &noop_qdisc); shutdown_scheduler_queue(dev, dev_ingress_queue(dev), &noop_qdisc);
qdisc_destroy(dev->qdisc); qdisc_put(dev->qdisc);
dev->qdisc = &noop_qdisc; dev->qdisc = &noop_qdisc;
WARN_ON(timer_pending(&dev->watchdog_timer)); WARN_ON(timer_pending(&dev->watchdog_timer));
......
...@@ -1092,7 +1092,7 @@ hfsc_destroy_class(struct Qdisc *sch, struct hfsc_class *cl) ...@@ -1092,7 +1092,7 @@ hfsc_destroy_class(struct Qdisc *sch, struct hfsc_class *cl)
struct hfsc_sched *q = qdisc_priv(sch); struct hfsc_sched *q = qdisc_priv(sch);
tcf_block_put(cl->block); tcf_block_put(cl->block);
qdisc_destroy(cl->qdisc); qdisc_put(cl->qdisc);
gen_kill_estimator(&cl->rate_est); gen_kill_estimator(&cl->rate_est);
if (cl != &q->root) if (cl != &q->root)
kfree(cl); kfree(cl);
......
...@@ -1208,7 +1208,7 @@ static void htb_destroy_class(struct Qdisc *sch, struct htb_class *cl) ...@@ -1208,7 +1208,7 @@ static void htb_destroy_class(struct Qdisc *sch, struct htb_class *cl)
{ {
if (!cl->level) { if (!cl->level) {
WARN_ON(!cl->leaf.q); WARN_ON(!cl->leaf.q);
qdisc_destroy(cl->leaf.q); qdisc_put(cl->leaf.q);
} }
gen_kill_estimator(&cl->rate_est); gen_kill_estimator(&cl->rate_est);
tcf_block_put(cl->block); tcf_block_put(cl->block);
...@@ -1409,7 +1409,7 @@ static int htb_change_class(struct Qdisc *sch, u32 classid, ...@@ -1409,7 +1409,7 @@ static int htb_change_class(struct Qdisc *sch, u32 classid,
/* turn parent into inner node */ /* turn parent into inner node */
qdisc_reset(parent->leaf.q); qdisc_reset(parent->leaf.q);
qdisc_tree_reduce_backlog(parent->leaf.q, qlen, backlog); qdisc_tree_reduce_backlog(parent->leaf.q, qlen, backlog);
qdisc_destroy(parent->leaf.q); qdisc_put(parent->leaf.q);
if (parent->prio_activity) if (parent->prio_activity)
htb_deactivate(q, parent); htb_deactivate(q, parent);
......
...@@ -65,7 +65,7 @@ static void mq_destroy(struct Qdisc *sch) ...@@ -65,7 +65,7 @@ static void mq_destroy(struct Qdisc *sch)
if (!priv->qdiscs) if (!priv->qdiscs)
return; return;
for (ntx = 0; ntx < dev->num_tx_queues && priv->qdiscs[ntx]; ntx++) for (ntx = 0; ntx < dev->num_tx_queues && priv->qdiscs[ntx]; ntx++)
qdisc_destroy(priv->qdiscs[ntx]); qdisc_put(priv->qdiscs[ntx]);
kfree(priv->qdiscs); kfree(priv->qdiscs);
} }
...@@ -119,7 +119,7 @@ static void mq_attach(struct Qdisc *sch) ...@@ -119,7 +119,7 @@ static void mq_attach(struct Qdisc *sch)
qdisc = priv->qdiscs[ntx]; qdisc = priv->qdiscs[ntx];
old = dev_graft_qdisc(qdisc->dev_queue, qdisc); old = dev_graft_qdisc(qdisc->dev_queue, qdisc);
if (old) if (old)
qdisc_destroy(old); qdisc_put(old);
#ifdef CONFIG_NET_SCHED #ifdef CONFIG_NET_SCHED
if (ntx < dev->real_num_tx_queues) if (ntx < dev->real_num_tx_queues)
qdisc_hash_add(qdisc, false); qdisc_hash_add(qdisc, false);
......
...@@ -40,7 +40,7 @@ static void mqprio_destroy(struct Qdisc *sch) ...@@ -40,7 +40,7 @@ static void mqprio_destroy(struct Qdisc *sch)
for (ntx = 0; for (ntx = 0;
ntx < dev->num_tx_queues && priv->qdiscs[ntx]; ntx < dev->num_tx_queues && priv->qdiscs[ntx];
ntx++) ntx++)
qdisc_destroy(priv->qdiscs[ntx]); qdisc_put(priv->qdiscs[ntx]);
kfree(priv->qdiscs); kfree(priv->qdiscs);
} }
...@@ -300,7 +300,7 @@ static void mqprio_attach(struct Qdisc *sch) ...@@ -300,7 +300,7 @@ static void mqprio_attach(struct Qdisc *sch)
qdisc = priv->qdiscs[ntx]; qdisc = priv->qdiscs[ntx];
old = dev_graft_qdisc(qdisc->dev_queue, qdisc); old = dev_graft_qdisc(qdisc->dev_queue, qdisc);
if (old) if (old)
qdisc_destroy(old); qdisc_put(old);
if (ntx < dev->real_num_tx_queues) if (ntx < dev->real_num_tx_queues)
qdisc_hash_add(qdisc, false); qdisc_hash_add(qdisc, false);
} }
......
...@@ -175,7 +175,7 @@ multiq_destroy(struct Qdisc *sch) ...@@ -175,7 +175,7 @@ multiq_destroy(struct Qdisc *sch)
tcf_block_put(q->block); tcf_block_put(q->block);
for (band = 0; band < q->bands; band++) for (band = 0; band < q->bands; band++)
qdisc_destroy(q->queues[band]); qdisc_put(q->queues[band]);
kfree(q->queues); kfree(q->queues);
} }
...@@ -204,7 +204,7 @@ static int multiq_tune(struct Qdisc *sch, struct nlattr *opt, ...@@ -204,7 +204,7 @@ static int multiq_tune(struct Qdisc *sch, struct nlattr *opt,
q->queues[i] = &noop_qdisc; q->queues[i] = &noop_qdisc;
qdisc_tree_reduce_backlog(child, child->q.qlen, qdisc_tree_reduce_backlog(child, child->q.qlen,
child->qstats.backlog); child->qstats.backlog);
qdisc_destroy(child); qdisc_put(child);
} }
} }
...@@ -228,7 +228,7 @@ static int multiq_tune(struct Qdisc *sch, struct nlattr *opt, ...@@ -228,7 +228,7 @@ static int multiq_tune(struct Qdisc *sch, struct nlattr *opt,
qdisc_tree_reduce_backlog(old, qdisc_tree_reduce_backlog(old,
old->q.qlen, old->q.qlen,
old->qstats.backlog); old->qstats.backlog);
qdisc_destroy(old); qdisc_put(old);
} }
sch_tree_unlock(sch); sch_tree_unlock(sch);
} }
......
...@@ -1022,7 +1022,7 @@ static void netem_destroy(struct Qdisc *sch) ...@@ -1022,7 +1022,7 @@ static void netem_destroy(struct Qdisc *sch)
qdisc_watchdog_cancel(&q->watchdog); qdisc_watchdog_cancel(&q->watchdog);
if (q->qdisc) if (q->qdisc)
qdisc_destroy(q->qdisc); qdisc_put(q->qdisc);
dist_free(q->delay_dist); dist_free(q->delay_dist);
dist_free(q->slot_dist); dist_free(q->slot_dist);
} }
......
...@@ -175,7 +175,7 @@ prio_destroy(struct Qdisc *sch) ...@@ -175,7 +175,7 @@ prio_destroy(struct Qdisc *sch)
tcf_block_put(q->block); tcf_block_put(q->block);
prio_offload(sch, NULL); prio_offload(sch, NULL);
for (prio = 0; prio < q->bands; prio++) for (prio = 0; prio < q->bands; prio++)
qdisc_destroy(q->queues[prio]); qdisc_put(q->queues[prio]);
} }
static int prio_tune(struct Qdisc *sch, struct nlattr *opt, static int prio_tune(struct Qdisc *sch, struct nlattr *opt,
...@@ -205,7 +205,7 @@ static int prio_tune(struct Qdisc *sch, struct nlattr *opt, ...@@ -205,7 +205,7 @@ static int prio_tune(struct Qdisc *sch, struct nlattr *opt,
extack); extack);
if (!queues[i]) { if (!queues[i]) {
while (i > oldbands) while (i > oldbands)
qdisc_destroy(queues[--i]); qdisc_put(queues[--i]);
return -ENOMEM; return -ENOMEM;
} }
} }
...@@ -220,7 +220,7 @@ static int prio_tune(struct Qdisc *sch, struct nlattr *opt, ...@@ -220,7 +220,7 @@ static int prio_tune(struct Qdisc *sch, struct nlattr *opt,
qdisc_tree_reduce_backlog(child, child->q.qlen, qdisc_tree_reduce_backlog(child, child->q.qlen,
child->qstats.backlog); child->qstats.backlog);
qdisc_destroy(child); qdisc_put(child);
} }
for (i = oldbands; i < q->bands; i++) { for (i = oldbands; i < q->bands; i++) {
......
...@@ -526,7 +526,7 @@ static int qfq_change_class(struct Qdisc *sch, u32 classid, u32 parentid, ...@@ -526,7 +526,7 @@ static int qfq_change_class(struct Qdisc *sch, u32 classid, u32 parentid,
return 0; return 0;
destroy_class: destroy_class:
qdisc_destroy(cl->qdisc); qdisc_put(cl->qdisc);
kfree(cl); kfree(cl);
return err; return err;
} }
...@@ -537,7 +537,7 @@ static void qfq_destroy_class(struct Qdisc *sch, struct qfq_class *cl) ...@@ -537,7 +537,7 @@ static void qfq_destroy_class(struct Qdisc *sch, struct qfq_class *cl)
qfq_rm_from_agg(q, cl); qfq_rm_from_agg(q, cl);
gen_kill_estimator(&cl->rate_est); gen_kill_estimator(&cl->rate_est);
qdisc_destroy(cl->qdisc); qdisc_put(cl->qdisc);
kfree(cl); kfree(cl);
} }
......
...@@ -181,7 +181,7 @@ static void red_destroy(struct Qdisc *sch) ...@@ -181,7 +181,7 @@ static void red_destroy(struct Qdisc *sch)
del_timer_sync(&q->adapt_timer); del_timer_sync(&q->adapt_timer);
red_offload(sch, false); red_offload(sch, false);
qdisc_destroy(q->qdisc); qdisc_put(q->qdisc);
} }
static const struct nla_policy red_policy[TCA_RED_MAX + 1] = { static const struct nla_policy red_policy[TCA_RED_MAX + 1] = {
...@@ -233,7 +233,7 @@ static int red_change(struct Qdisc *sch, struct nlattr *opt, ...@@ -233,7 +233,7 @@ static int red_change(struct Qdisc *sch, struct nlattr *opt,
if (child) { if (child) {
qdisc_tree_reduce_backlog(q->qdisc, q->qdisc->q.qlen, qdisc_tree_reduce_backlog(q->qdisc, q->qdisc->q.qlen,
q->qdisc->qstats.backlog); q->qdisc->qstats.backlog);
qdisc_destroy(q->qdisc); qdisc_put(q->qdisc);
q->qdisc = child; q->qdisc = child;
} }
......
...@@ -469,7 +469,7 @@ static void sfb_destroy(struct Qdisc *sch) ...@@ -469,7 +469,7 @@ static void sfb_destroy(struct Qdisc *sch)
struct sfb_sched_data *q = qdisc_priv(sch); struct sfb_sched_data *q = qdisc_priv(sch);
tcf_block_put(q->block); tcf_block_put(q->block);
qdisc_destroy(q->qdisc); qdisc_put(q->qdisc);
} }
static const struct nla_policy sfb_policy[TCA_SFB_MAX + 1] = { static const struct nla_policy sfb_policy[TCA_SFB_MAX + 1] = {
...@@ -523,7 +523,7 @@ static int sfb_change(struct Qdisc *sch, struct nlattr *opt, ...@@ -523,7 +523,7 @@ static int sfb_change(struct Qdisc *sch, struct nlattr *opt,
qdisc_tree_reduce_backlog(q->qdisc, q->qdisc->q.qlen, qdisc_tree_reduce_backlog(q->qdisc, q->qdisc->q.qlen,
q->qdisc->qstats.backlog); q->qdisc->qstats.backlog);
qdisc_destroy(q->qdisc); qdisc_put(q->qdisc);
q->qdisc = child; q->qdisc = child;
q->rehash_interval = msecs_to_jiffies(ctl->rehash_interval); q->rehash_interval = msecs_to_jiffies(ctl->rehash_interval);
......
...@@ -392,7 +392,7 @@ static int tbf_change(struct Qdisc *sch, struct nlattr *opt, ...@@ -392,7 +392,7 @@ static int tbf_change(struct Qdisc *sch, struct nlattr *opt,
if (child) { if (child) {
qdisc_tree_reduce_backlog(q->qdisc, q->qdisc->q.qlen, qdisc_tree_reduce_backlog(q->qdisc, q->qdisc->q.qlen,
q->qdisc->qstats.backlog); q->qdisc->qstats.backlog);
qdisc_destroy(q->qdisc); qdisc_put(q->qdisc);
q->qdisc = child; q->qdisc = child;
} }
q->limit = qopt->limit; q->limit = qopt->limit;
...@@ -438,7 +438,7 @@ static void tbf_destroy(struct Qdisc *sch) ...@@ -438,7 +438,7 @@ static void tbf_destroy(struct Qdisc *sch)
struct tbf_sched_data *q = qdisc_priv(sch); struct tbf_sched_data *q = qdisc_priv(sch);
qdisc_watchdog_cancel(&q->watchdog); qdisc_watchdog_cancel(&q->watchdog);
qdisc_destroy(q->qdisc); qdisc_put(q->qdisc);
} }
static int tbf_dump(struct Qdisc *sch, struct sk_buff *skb) static int tbf_dump(struct Qdisc *sch, struct sk_buff *skb)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment