From: Eric Dumazet <edumazet@google.com>
To: "David S . Miller" <davem@davemloft.net>,
Jakub Kicinski <kuba@kernel.org>,
Paolo Abeni <pabeni@redhat.com>
Cc: Simon Horman <horms@kernel.org>,
Jamal Hadi Salim <jhs@mojatatu.com>,
Jiri Pirko <jiri@resnulli.us>,
Kuniyuki Iwashima <kuniyu@google.com>,
netdev@vger.kernel.org, eric.dumazet@gmail.com,
Eric Dumazet <edumazet@google.com>
Subject: [PATCH net-next 00/15] net/sched: no longer acquire RTNL in qdisc dumps
Date: Wed, 8 Apr 2026 12:55:56 +0000 [thread overview]
Message-ID: <20260408125611.3592751-1-edumazet@google.com> (raw)
This (large) series bring RTNL avoidance to qdisc dumps.
We first add annotations for data-races, so that most dump methods
can run in parallel with data path.
Then change mq and mqprio to no longer acquire each children
qdisc spinlock.
Last patch replaces RTNL with RCU for tc_dump_qdisc() and the
qdisc ops->dump() methods.
Series was too big, RTNL avoidance for class dumps will be done later.
Eric Dumazet (15):
net/sched: rename qstats_overlimit_inc() to qstats_cpu_overlimit_inc()
net/sched: add qstats_cpu_drop_inc() helper
net/sched: add READ_ONCE() in gnet_stats_add_queue[_cpu]
net/sched: add qdisc_qlen_inc() and qdisc_qlen_dec()
net/sched: annotate data-races around sch->qstats.backlog
net/sched: sch_sfb: annotate data-races in sfb_dump_stats()
net/sched: sch_red: annotate data-races in red_dump_stats()
net/sched: sch_fq_codel: remove data-races from fq_codel_dump_stats()
net/sched: sch_pie: annotate data-races in pie_dump_stats()
net/sched: sch_fq_pie: annotate data-races in fq_pie_dump_stats()
net_sched: sch_hhf: annotate data-races in hhf_dump_stats()
net/sched: sch_choke: annotate data-races in choke_dump_stats()
net/sched: sch_cake: annotate data-races in cake_dump_stats()
net/sched: mq: no longer acquire qdisc spinlocks in dump operations
net/sched: convert tc_dump_qdisc() to RCU
include/net/act_api.h | 4 +-
include/net/gen_stats.h | 9 +-
include/net/pie.h | 2 +-
include/net/sch_generic.h | 75 ++++++--
net/core/gen_estimator.c | 24 ++-
net/core/gen_stats.c | 42 ++---
net/sched/act_api.c | 2 +-
net/sched/act_bpf.c | 2 +-
net/sched/act_ife.c | 12 +-
net/sched/act_mpls.c | 2 +-
net/sched/act_police.c | 4 +-
net/sched/act_skbedit.c | 2 +-
net/sched/act_skbmod.c | 2 +-
net/sched/sch_api.c | 25 ++-
net/sched/sch_cake.c | 353 +++++++++++++++++++++-----------------
net/sched/sch_cbs.c | 6 +-
net/sched/sch_choke.c | 34 ++--
net/sched/sch_codel.c | 2 +-
net/sched/sch_drr.c | 6 +-
net/sched/sch_dualpi2.c | 4 +-
net/sched/sch_etf.c | 8 +-
net/sched/sch_ets.c | 6 +-
net/sched/sch_fq.c | 8 +-
net/sched/sch_fq_codel.c | 16 +-
net/sched/sch_fq_pie.c | 31 ++--
net/sched/sch_generic.c | 8 +-
net/sched/sch_gred.c | 4 +-
net/sched/sch_hfsc.c | 6 +-
net/sched/sch_hhf.c | 26 +--
net/sched/sch_htb.c | 6 +-
net/sched/sch_mq.c | 30 ++--
net/sched/sch_mqprio.c | 69 ++++----
net/sched/sch_multiq.c | 4 +-
net/sched/sch_netem.c | 12 +-
net/sched/sch_pie.c | 38 ++--
net/sched/sch_prio.c | 6 +-
net/sched/sch_qfq.c | 8 +-
net/sched/sch_red.c | 37 ++--
net/sched/sch_sfb.c | 54 +++---
net/sched/sch_sfq.c | 9 +-
net/sched/sch_skbprio.c | 4 +-
net/sched/sch_taprio.c | 20 +--
net/sched/sch_tbf.c | 10 +-
net/sched/sch_teql.c | 2 +-
44 files changed, 571 insertions(+), 463 deletions(-)
--
2.53.0.1213.gd9a14994de-goog
next reply other threads:[~2026-04-08 12:56 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-04-08 12:55 Eric Dumazet [this message]
2026-04-08 12:55 ` [PATCH net-next 01/15] net/sched: rename qstats_overlimit_inc() to qstats_cpu_overlimit_inc() Eric Dumazet
2026-04-08 12:55 ` [PATCH net-next 02/15] net/sched: add qstats_cpu_drop_inc() helper Eric Dumazet
2026-04-08 12:55 ` [PATCH net-next 03/15] net/sched: add READ_ONCE() in gnet_stats_add_queue[_cpu] Eric Dumazet
2026-04-08 12:56 ` [PATCH net-next 04/15] net/sched: add qdisc_qlen_inc() and qdisc_qlen_dec() Eric Dumazet
2026-04-08 12:56 ` [PATCH net-next 05/15] net/sched: annotate data-races around sch->qstats.backlog Eric Dumazet
2026-04-08 12:56 ` [PATCH net-next 06/15] net/sched: sch_sfb: annotate data-races in sfb_dump_stats() Eric Dumazet
2026-04-08 12:56 ` [PATCH net-next 07/15] net/sched: sch_red: annotate data-races in red_dump_stats() Eric Dumazet
2026-04-08 12:56 ` [PATCH net-next 08/15] net/sched: sch_fq_codel: remove data-races from fq_codel_dump_stats() Eric Dumazet
2026-04-08 12:56 ` [PATCH net-next 09/15] net/sched: sch_pie: annotate data-races in pie_dump_stats() Eric Dumazet
2026-04-08 12:56 ` [PATCH net-next 10/15] net/sched: sch_fq_pie: annotate data-races in fq_pie_dump_stats() Eric Dumazet
2026-04-08 12:56 ` [PATCH net-next 11/15] net_sched: sch_hhf: annotate data-races in hhf_dump_stats() Eric Dumazet
2026-04-08 12:56 ` [PATCH net-next 12/15] net/sched: sch_choke: annotate data-races in choke_dump_stats() Eric Dumazet
2026-04-08 12:56 ` [PATCH net-next 13/15] net/sched: sch_cake: annotate data-races in cake_dump_stats() Eric Dumazet
2026-04-08 12:56 ` [PATCH net-next 14/15] net/sched: mq: no longer acquire qdisc spinlocks in dump operations Eric Dumazet
2026-04-08 12:56 ` [PATCH net-next 15/15] net/sched: convert tc_dump_qdisc() to RCU Eric Dumazet
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20260408125611.3592751-1-edumazet@google.com \
--to=edumazet@google.com \
--cc=davem@davemloft.net \
--cc=eric.dumazet@gmail.com \
--cc=horms@kernel.org \
--cc=jhs@mojatatu.com \
--cc=jiri@resnulli.us \
--cc=kuba@kernel.org \
--cc=kuniyu@google.com \
--cc=netdev@vger.kernel.org \
--cc=pabeni@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox