Commit b03f4672 authored by Patrick McHardy's avatar Patrick McHardy Committed by David S. Miller

[NET_SCHED]: sch_netem: use nla_parse_nested_compat

Replace open coded equivalent of nla_parse_nested_compat().
Signed-off-by: default avatarPatrick McHardy <kaber@trash.net>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent f5e5cb75
...@@ -407,13 +407,18 @@ static int get_corrupt(struct Qdisc *sch, const struct nlattr *attr) ...@@ -407,13 +407,18 @@ static int get_corrupt(struct Qdisc *sch, const struct nlattr *attr)
static int netem_change(struct Qdisc *sch, struct nlattr *opt) static int netem_change(struct Qdisc *sch, struct nlattr *opt)
{ {
struct netem_sched_data *q = qdisc_priv(sch); struct netem_sched_data *q = qdisc_priv(sch);
struct nlattr *tb[TCA_NETEM_MAX + 1];
struct tc_netem_qopt *qopt; struct tc_netem_qopt *qopt;
int ret; int ret;
if (opt == NULL || nla_len(opt) < sizeof(*qopt)) if (opt == NULL)
return -EINVAL; return -EINVAL;
qopt = nla_data(opt); ret = nla_parse_nested_compat(tb, TCA_NETEM_MAX, opt, NULL, qopt,
sizeof(*qopt));
if (ret < 0)
return ret;
ret = set_fifo_limit(q->qdisc, qopt->limit); ret = set_fifo_limit(q->qdisc, qopt->limit);
if (ret) { if (ret) {
pr_debug("netem: can't set fifo limit\n"); pr_debug("netem: can't set fifo limit\n");
...@@ -434,39 +439,28 @@ static int netem_change(struct Qdisc *sch, struct nlattr *opt) ...@@ -434,39 +439,28 @@ static int netem_change(struct Qdisc *sch, struct nlattr *opt)
if (q->gap) if (q->gap)
q->reorder = ~0; q->reorder = ~0;
/* Handle nested options after initial queue options. if (tb[TCA_NETEM_CORR]) {
* Should have put all options in nested format but too late now. ret = get_correlation(sch, tb[TCA_NETEM_CORR]);
*/ if (ret)
if (nla_len(opt) > sizeof(*qopt)) { return ret;
struct nlattr *tb[TCA_NETEM_MAX + 1]; }
if (nla_parse(tb, TCA_NETEM_MAX,
nla_data(opt) + sizeof(*qopt),
nla_len(opt) - sizeof(*qopt), NULL))
return -EINVAL;
if (tb[TCA_NETEM_CORR]) {
ret = get_correlation(sch, tb[TCA_NETEM_CORR]);
if (ret)
return ret;
}
if (tb[TCA_NETEM_DELAY_DIST]) { if (tb[TCA_NETEM_DELAY_DIST]) {
ret = get_dist_table(sch, tb[TCA_NETEM_DELAY_DIST]); ret = get_dist_table(sch, tb[TCA_NETEM_DELAY_DIST]);
if (ret) if (ret)
return ret; return ret;
} }
if (tb[TCA_NETEM_REORDER]) { if (tb[TCA_NETEM_REORDER]) {
ret = get_reorder(sch, tb[TCA_NETEM_REORDER]); ret = get_reorder(sch, tb[TCA_NETEM_REORDER]);
if (ret) if (ret)
return ret; return ret;
} }
if (tb[TCA_NETEM_CORRUPT]) { if (tb[TCA_NETEM_CORRUPT]) {
ret = get_corrupt(sch, tb[TCA_NETEM_CORRUPT]); ret = get_corrupt(sch, tb[TCA_NETEM_CORRUPT]);
if (ret) if (ret)
return ret; return ret;
}
} }
return 0; return 0;
......
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