|
@@ -1477,11 +1477,22 @@ static int htb_change_class(struct Qdisc *sch, u32 classid,
|
|
|
sch_tree_lock(sch);
|
|
|
}
|
|
|
|
|
|
+ rate64 = tb[TCA_HTB_RATE64] ? nla_get_u64(tb[TCA_HTB_RATE64]) : 0;
|
|
|
+
|
|
|
+ ceil64 = tb[TCA_HTB_CEIL64] ? nla_get_u64(tb[TCA_HTB_CEIL64]) : 0;
|
|
|
+
|
|
|
+ psched_ratecfg_precompute(&cl->rate, &hopt->rate, rate64);
|
|
|
+ psched_ratecfg_precompute(&cl->ceil, &hopt->ceil, ceil64);
|
|
|
+
|
|
|
/* it used to be a nasty bug here, we have to check that node
|
|
|
* is really leaf before changing cl->un.leaf !
|
|
|
*/
|
|
|
if (!cl->level) {
|
|
|
- cl->quantum = hopt->rate.rate / q->rate2quantum;
|
|
|
+ u64 quantum = cl->rate.rate_bytes_ps;
|
|
|
+
|
|
|
+ do_div(quantum, q->rate2quantum);
|
|
|
+ cl->quantum = min_t(u64, quantum, INT_MAX);
|
|
|
+
|
|
|
if (!hopt->quantum && cl->quantum < 1000) {
|
|
|
pr_warning(
|
|
|
"HTB: quantum of class %X is small. Consider r2q change.\n",
|
|
@@ -1500,13 +1511,6 @@ static int htb_change_class(struct Qdisc *sch, u32 classid,
|
|
|
cl->prio = TC_HTB_NUMPRIO - 1;
|
|
|
}
|
|
|
|
|
|
- rate64 = tb[TCA_HTB_RATE64] ? nla_get_u64(tb[TCA_HTB_RATE64]) : 0;
|
|
|
-
|
|
|
- ceil64 = tb[TCA_HTB_CEIL64] ? nla_get_u64(tb[TCA_HTB_CEIL64]) : 0;
|
|
|
-
|
|
|
- psched_ratecfg_precompute(&cl->rate, &hopt->rate, rate64);
|
|
|
- psched_ratecfg_precompute(&cl->ceil, &hopt->ceil, ceil64);
|
|
|
-
|
|
|
cl->buffer = PSCHED_TICKS2NS(hopt->buffer);
|
|
|
cl->cbuffer = PSCHED_TICKS2NS(hopt->cbuffer);
|
|
|
|