[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20250630164309.724b9ba1@kernel.org>
Date: Mon, 30 Jun 2025 16:43:09 -0700
From: Jakub Kicinski <kuba@...nel.org>
To: "Chia-Yu Chang (Nokia)" <chia-yu.chang@...ia-bell-labs.com>
Cc: "alok.a.tiwari@...cle.com" <alok.a.tiwari@...cle.com>,
"pctammela@...atatu.com" <pctammela@...atatu.com>, "horms@...nel.org"
<horms@...nel.org>, "donald.hunter@...il.com" <donald.hunter@...il.com>,
"xandfury@...il.com" <xandfury@...il.com>, "netdev@...r.kernel.org"
<netdev@...r.kernel.org>, "dave.taht@...il.com" <dave.taht@...il.com>,
"pabeni@...hat.com" <pabeni@...hat.com>, "jhs@...atatu.com"
<jhs@...atatu.com>, "stephen@...workplumber.org"
<stephen@...workplumber.org>, "xiyou.wangcong@...il.com"
<xiyou.wangcong@...il.com>, "jiri@...nulli.us" <jiri@...nulli.us>,
"davem@...emloft.net" <davem@...emloft.net>, "edumazet@...gle.com"
<edumazet@...gle.com>, "andrew+netdev@...n.ch" <andrew+netdev@...n.ch>,
"ast@...erby.net" <ast@...erby.net>, "liuhangbin@...il.com"
<liuhangbin@...il.com>, "shuah@...nel.org" <shuah@...nel.org>,
"linux-kselftest@...r.kernel.org" <linux-kselftest@...r.kernel.org>,
"ij@...nel.org" <ij@...nel.org>, "ncardwell@...gle.com"
<ncardwell@...gle.com>, "Koen De Schepper (Nokia)"
<koen.de_schepper@...ia-bell-labs.com>, "g.white@...lelabs.com"
<g.white@...lelabs.com>, "ingemar.s.johansson@...csson.com"
<ingemar.s.johansson@...csson.com>, "mirja.kuehlewind@...csson.com"
<mirja.kuehlewind@...csson.com>, "cheshire@...le.com" <cheshire@...le.com>,
"rs.ietf@....at" <rs.ietf@....at>, "Jason_Livingood@...cast.com"
<Jason_Livingood@...cast.com>, "vidhi_goel@...le.com"
<vidhi_goel@...le.com>
Subject: Re: [PATCH v20 net-next 1/6] sched: Struct definition and parsing
of dualpi2 qdisc
On Mon, 30 Jun 2025 17:04:56 +0000 Chia-Yu Chang (Nokia) wrote:
> > > This still needs 2 WRITE_ONCE even "step_thresh" (NLA_U32) and
> > > "step_in_packtes" (NLA_FLAG) are replaced with "step_pkt_thresh"
> > > (NLA_U32) and "step_time_thresh" (NLA_U32) - which was proposed in my
> > > another email.
> >
> > If you don't understand the question - ask for clarifications :/
>
> You are right.
>
> Could you elaborate on the orignal comment "And the block under which
> I'm responding is performing two dependent writes, one to
> ->step_in_packets and the other to ->step_thresh a change which is
> definitely not atomic.."?
>
> I don't see we access the same atomic variable multiple times in a
> single expression, the 2 WRITE_ONCE() are in different expressions.
>
> And, in the last WRITE_ONCE(), what we access are local variables:
> "step_pkt" "step_th", will it create problem?
Not really a problem, but what I'm saying is that I don't understand
why all the writes are sprinkled with WRITE_ONCE(). You take
sch_tree_lock(sch);
to block data path and the control path is under rtnl_lock. So why the
WRITE_ONCE()? WRITE_ONCE() is used to annotate writes which can be read
concurrently without holding relevant locks.
Powered by blists - more mailing lists