[PKT_SCHED]: Restore TBF change semantic
When TBF was converted to a classful qdisc, the semantic of the limit parameter was broken. On initilization an inner bfifo qdisc is created for backwards compatibility, when changing parameters however the new limit is ignored and the current child qdisc remains in place. Always replace the child qdisc by the default bfifo when limit is above zero, otherwise don't touch the inner qdisc. Current tc version enforce a limit above zero, other users can avoid creating the inner qdisc by using zero. Signed-off-by: Patrick McHardy <kaber@trash.net> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
cdc7f8e362
commit
053cfed75d
1 changed files with 3 additions and 2 deletions
|
@ -341,13 +341,14 @@ static int tbf_change(struct Qdisc* sch, struct rtattr *opt)
|
||||||
if (max_size < 0)
|
if (max_size < 0)
|
||||||
goto done;
|
goto done;
|
||||||
|
|
||||||
if (q->qdisc == &noop_qdisc) {
|
if (qopt->limit > 0) {
|
||||||
if ((child = tbf_create_dflt_qdisc(sch->dev, qopt->limit)) == NULL)
|
if ((child = tbf_create_dflt_qdisc(sch->dev, qopt->limit)) == NULL)
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
sch_tree_lock(sch);
|
sch_tree_lock(sch);
|
||||||
if (child) q->qdisc = child;
|
if (child)
|
||||||
|
qdisc_destroy(xchg(&q->qdisc, child));
|
||||||
q->limit = qopt->limit;
|
q->limit = qopt->limit;
|
||||||
q->mtu = qopt->mtu;
|
q->mtu = qopt->mtu;
|
||||||
q->max_size = max_size;
|
q->max_size = max_size;
|
||||||
|
|
Loading…
Reference in a new issue