Lines Matching defs:sch
142 static void tbf_offload_change(struct Qdisc *sch)
144 struct tbf_sched_data *q = qdisc_priv(sch);
145 struct net_device *dev = qdisc_dev(sch);
152 qopt.handle = sch->handle;
153 qopt.parent = sch->parent;
156 qopt.replace_params.qstats = &sch->qstats;
161 static void tbf_offload_destroy(struct Qdisc *sch)
163 struct net_device *dev = qdisc_dev(sch);
170 qopt.handle = sch->handle;
171 qopt.parent = sch->parent;
175 static int tbf_offload_dump(struct Qdisc *sch)
180 qopt.handle = sch->handle;
181 qopt.parent = sch->parent;
182 qopt.stats.bstats = &sch->bstats;
183 qopt.stats.qstats = &sch->qstats;
185 return qdisc_offload_dump_helper(sch, TC_SETUP_QDISC_TBF, &qopt);
188 static void tbf_offload_graft(struct Qdisc *sch, struct Qdisc *new,
192 .handle = sch->handle,
193 .parent = sch->parent,
198 qdisc_offload_graft_helper(qdisc_dev(sch), sch, new, old,
205 static int tbf_segment(struct sk_buff *skb, struct Qdisc *sch,
208 struct tbf_sched_data *q = qdisc_priv(sch);
217 return qdisc_drop(skb, sch, to_free);
227 qdisc_qstats_drop(sch);
232 sch->q.qlen += nb;
234 qdisc_tree_reduce_backlog(sch, 1 - nb, prev_len - len);
239 static int tbf_enqueue(struct sk_buff *skb, struct Qdisc *sch,
242 struct tbf_sched_data *q = qdisc_priv(sch);
249 return tbf_segment(skb, sch, to_free);
250 return qdisc_drop(skb, sch, to_free);
255 qdisc_qstats_drop(sch);
259 sch->qstats.backlog += len;
260 sch->q.qlen++;
269 static struct sk_buff *tbf_dequeue(struct Qdisc *sch)
271 struct tbf_sched_data *q = qdisc_priv(sch);
304 qdisc_qstats_backlog_dec(sch, skb);
305 sch->q.qlen--;
306 qdisc_bstats_update(sch, skb);
324 qdisc_qstats_overlimit(sch);
329 static void tbf_reset(struct Qdisc *sch)
331 struct tbf_sched_data *q = qdisc_priv(sch);
350 static int tbf_change(struct Qdisc *sch, struct nlattr *opt,
354 struct tbf_sched_data *q = qdisc_priv(sch);
421 if (max_size < psched_mtu(qdisc_dev(sch)))
423 max_size, qdisc_dev(sch)->name,
424 psched_mtu(qdisc_dev(sch)));
436 child = fifo_create_dflt(sch, &bfifo_qdisc_ops, qopt->limit,
447 sch_tree_lock(sch);
469 sch_tree_unlock(sch);
473 tbf_offload_change(sch);
478 static int tbf_init(struct Qdisc *sch, struct nlattr *opt,
481 struct tbf_sched_data *q = qdisc_priv(sch);
483 qdisc_watchdog_init(&q->watchdog, sch);
491 return tbf_change(sch, opt, extack);
494 static void tbf_destroy(struct Qdisc *sch)
496 struct tbf_sched_data *q = qdisc_priv(sch);
499 tbf_offload_destroy(sch);
503 static int tbf_dump(struct Qdisc *sch, struct sk_buff *skb)
505 struct tbf_sched_data *q = qdisc_priv(sch);
510 err = tbf_offload_dump(sch);
545 static int tbf_dump_class(struct Qdisc *sch, unsigned long cl,
548 struct tbf_sched_data *q = qdisc_priv(sch);
556 static int tbf_graft(struct Qdisc *sch, unsigned long arg, struct Qdisc *new,
559 struct tbf_sched_data *q = qdisc_priv(sch);
564 *old = qdisc_replace(sch, new, &q->qdisc);
566 tbf_offload_graft(sch, new, *old, extack);
570 static struct Qdisc *tbf_leaf(struct Qdisc *sch, unsigned long arg)
572 struct tbf_sched_data *q = qdisc_priv(sch);
576 static unsigned long tbf_find(struct Qdisc *sch, u32 classid)
581 static void tbf_walk(struct Qdisc *sch, struct qdisc_walker *walker)
584 tc_qdisc_stats_dump(sch, 1, walker);