From: Yury Norov <yury.norov@gmail.com>
To: Ilya Maximets <i.maximets@ovn.org>
Cc: Aaron Conole <aconole@redhat.com>,
Eelco Chaudron <echaudro@redhat.com>,
"David S. Miller" <davem@davemloft.net>,
Eric Dumazet <edumazet@google.com>,
Jakub Kicinski <kuba@kernel.org>, Paolo Abeni <pabeni@redhat.com>,
Simon Horman <horms@kernel.org>,
netdev@vger.kernel.org, dev@openvswitch.org,
linux-kernel@vger.kernel.org
Subject: Re: [PATCH] net: openvswitch: Use for_each_cpu_from() where appropriate
Date: Thu, 14 Aug 2025 17:37:42 -0400 [thread overview]
Message-ID: <aJ5XJmDa-Ltpdmn3@yury> (raw)
In-Reply-To: <2dc70249-7de2-4178-9184-2d50cc0dffe9@ovn.org>
On Thu, Aug 14, 2025 at 11:21:02PM +0200, Ilya Maximets wrote:
> On 8/14/25 11:05 PM, Yury Norov wrote:
> > On Thu, Aug 14, 2025 at 10:49:30PM +0200, Ilya Maximets wrote:
> >> On 8/14/25 9:58 PM, Yury Norov wrote:
> >>> From: Yury Norov (NVIDIA) <yury.norov@gmail.com>
> >>>
> >>> Openvswitch opencodes for_each_cpu_from(). Fix it and drop some
> >>> housekeeping code.
> >>>
> >>> Signed-off-by: Yury Norov (NVIDIA) <yury.norov@gmail.com>
> >>> ---
> >>> net/openvswitch/flow.c | 14 ++++++--------
> >>> net/openvswitch/flow_table.c | 8 ++++----
> >>> 2 files changed, 10 insertions(+), 12 deletions(-)
> >>>
> >>> diff --git a/net/openvswitch/flow.c b/net/openvswitch/flow.c
> >>> index b80bd3a90773..b464ab120731 100644
> >>> --- a/net/openvswitch/flow.c
> >>> +++ b/net/openvswitch/flow.c
> >>> @@ -129,15 +129,14 @@ void ovs_flow_stats_get(const struct sw_flow *flow,
> >>> struct ovs_flow_stats *ovs_stats,
> >>> unsigned long *used, __be16 *tcp_flags)
> >>> {
> >>> - int cpu;
> >>> + /* CPU 0 is always considered */
> >>> + unsigned int cpu = 1;
> >>
> >> Hmm. I'm a bit confused here. Where is CPU 0 considered if we start
> >> iteration from 1?
> >
> > I didn't touch this part of the original comment, as you see, and I'm
> > not a domain expert, so don't know what does this wording mean.
> >
> > Most likely 'always considered' means that CPU0 is not accounted in this
> > statistics.
> >
> >>> *used = 0;
> >>> *tcp_flags = 0;
> >>> memset(ovs_stats, 0, sizeof(*ovs_stats));
> >>>
> >>> - /* We open code this to make sure cpu 0 is always considered */
> >>> - for (cpu = 0; cpu < nr_cpu_ids;
> >>> - cpu = cpumask_next(cpu, flow->cpu_used_mask)) {
> >>> + for_each_cpu_from(cpu, flow->cpu_used_mask) {
> >>
> >> And why it needs to be a for_each_cpu_from() and not just for_each_cpu() ?
> >
> > The original code explicitly ignores CPU0.
>
> No, it's not. The loop explicitly starts from zero. And the comments
> are saying that the loop is open-coded specifically to always have zero
> in the iteration.
OK, I see now. That indentation has fooled me. So the comment means
that CPU0 is included even if flow->cpu_used_mask has it cleared. And
to avoid opencoding, we need to do like:
for_each_cpu_or(cpu, flow->cpu_used_mask, cpumask_of(0))
I'll send v2 shortly.
Thanks for pointing to this, eagle eye :).
next prev parent reply other threads:[~2025-08-14 21:37 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-08-14 19:58 [PATCH] net: openvswitch: Use for_each_cpu_from() where appropriate Yury Norov
2025-08-14 20:49 ` Ilya Maximets
2025-08-14 21:05 ` Yury Norov
2025-08-14 21:21 ` Ilya Maximets
2025-08-14 21:37 ` Yury Norov [this message]
2025-08-14 23:06 ` Ilya Maximets
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=aJ5XJmDa-Ltpdmn3@yury \
--to=yury.norov@gmail.com \
--cc=aconole@redhat.com \
--cc=davem@davemloft.net \
--cc=dev@openvswitch.org \
--cc=echaudro@redhat.com \
--cc=edumazet@google.com \
--cc=horms@kernel.org \
--cc=i.maximets@ovn.org \
--cc=kuba@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--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;
as well as URLs for NNTP newsgroup(s).