Message ID | 0c07bd5b72c67a2edf126cd2c6a9daadddb3ca95.1684887977.git.peilin.ye@bytedance.com (mailing list archive) |
---|---|
State | Superseded |
Delegated to: | Netdev Maintainers |
Headers | show |
Series | net/sched: Fixes for sch_ingress and sch_clsact | expand |
On 23/05/2023 22:18, Peilin Ye wrote: > From: Peilin Ye <peilin.ye@bytedance.com> > > clsact Qdiscs are only supposed to be created under TC_H_CLSACT (which > equals TC_H_INGRESS). Return -EOPNOTSUPP if 'parent' is not > TC_H_CLSACT. > > Fixes: 1f211a1b929c ("net, sched: add clsact qdisc") > Signed-off-by: Peilin Ye <peilin.ye@bytedance.com> Tested-by: Pedro Tammela <pctammela@mojatatu.com> > --- > change in v5: > - avoid underflowing @egress_needed_key in ->destroy(), reported by > Pedro > > change in v3, v4: > - add in-body From: tag > > net/sched/sch_ingress.c | 6 ++++++ > 1 file changed, 6 insertions(+) > > diff --git a/net/sched/sch_ingress.c b/net/sched/sch_ingress.c > index f9ef6deb2770..35963929e117 100644 > --- a/net/sched/sch_ingress.c > +++ b/net/sched/sch_ingress.c > @@ -225,6 +225,9 @@ static int clsact_init(struct Qdisc *sch, struct nlattr *opt, > struct net_device *dev = qdisc_dev(sch); > int err; > > + if (sch->parent != TC_H_CLSACT) > + return -EOPNOTSUPP; > + > net_inc_ingress_queue(); > net_inc_egress_queue(); > > @@ -254,6 +257,9 @@ static void clsact_destroy(struct Qdisc *sch) > { > struct clsact_sched_data *q = qdisc_priv(sch); > > + if (sch->parent != TC_H_CLSACT) > + return; > + > tcf_block_put_ext(q->egress_block, sch, &q->egress_block_info); > tcf_block_put_ext(q->ingress_block, sch, &q->ingress_block_info); >
On Wed, May 24, 2023 at 11:38 AM Pedro Tammela <pctammela@mojatatu.com> wrote: > > On 23/05/2023 22:18, Peilin Ye wrote: > > From: Peilin Ye <peilin.ye@bytedance.com> > > > > clsact Qdiscs are only supposed to be created under TC_H_CLSACT (which > > equals TC_H_INGRESS). Return -EOPNOTSUPP if 'parent' is not > > TC_H_CLSACT. > > > > Fixes: 1f211a1b929c ("net, sched: add clsact qdisc") > > Signed-off-by: Peilin Ye <peilin.ye@bytedance.com> > > Tested-by: Pedro Tammela <pctammela@mojatatu.com> > Reviewed-by: Jamal Hadi Salim <jhs@mojatatu.com> Acked-by: Jamal Hadi Salim <jhs@mojatatu.com> cheers, jamal > > --- > > change in v5: > > - avoid underflowing @egress_needed_key in ->destroy(), reported by > > Pedro > > > > change in v3, v4: > > - add in-body From: tag > > > > net/sched/sch_ingress.c | 6 ++++++ > > 1 file changed, 6 insertions(+) > > > > diff --git a/net/sched/sch_ingress.c b/net/sched/sch_ingress.c > > index f9ef6deb2770..35963929e117 100644 > > --- a/net/sched/sch_ingress.c > > +++ b/net/sched/sch_ingress.c > > @@ -225,6 +225,9 @@ static int clsact_init(struct Qdisc *sch, struct nlattr *opt, > > struct net_device *dev = qdisc_dev(sch); > > int err; > > > > + if (sch->parent != TC_H_CLSACT) > > + return -EOPNOTSUPP; > > + > > net_inc_ingress_queue(); > > net_inc_egress_queue(); > > > > @@ -254,6 +257,9 @@ static void clsact_destroy(struct Qdisc *sch) > > { > > struct clsact_sched_data *q = qdisc_priv(sch); > > > > + if (sch->parent != TC_H_CLSACT) > > + return; > > + > > tcf_block_put_ext(q->egress_block, sch, &q->egress_block_info); > > tcf_block_put_ext(q->ingress_block, sch, &q->ingress_block_info); > > >
diff --git a/net/sched/sch_ingress.c b/net/sched/sch_ingress.c index f9ef6deb2770..35963929e117 100644 --- a/net/sched/sch_ingress.c +++ b/net/sched/sch_ingress.c @@ -225,6 +225,9 @@ static int clsact_init(struct Qdisc *sch, struct nlattr *opt, struct net_device *dev = qdisc_dev(sch); int err; + if (sch->parent != TC_H_CLSACT) + return -EOPNOTSUPP; + net_inc_ingress_queue(); net_inc_egress_queue(); @@ -254,6 +257,9 @@ static void clsact_destroy(struct Qdisc *sch) { struct clsact_sched_data *q = qdisc_priv(sch); + if (sch->parent != TC_H_CLSACT) + return; + tcf_block_put_ext(q->egress_block, sch, &q->egress_block_info); tcf_block_put_ext(q->ingress_block, sch, &q->ingress_block_info);