From: "Sverdlin, Alexander" <alexander.sverdlin@siemens.com>
To: "wbg@kernel.org" <wbg@kernel.org>
Cc: "o.rempel@pengutronix.de" <o.rempel@pengutronix.de>,
"kernel@pengutronix.de" <kernel@pengutronix.de>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
"linux-iio@vger.kernel.org" <linux-iio@vger.kernel.org>
Subject: Re: [PATCH] counter: interrupt-cnt: Protect enable/disable OPs with mutex
Date: Fri, 2 May 2025 16:32:02 +0000 [thread overview]
Message-ID: <f1e4a1db585e58aca766d0f48ebce3a28986944f.camel@siemens.com> (raw)
In-Reply-To: <aBSv1pJ1mulT78gn@ishi>
Thanks for the quick reply William,
On Fri, 2025-05-02 at 20:43 +0900, William Breathitt Gray wrote:
> > > From: Alexander Sverdlin <alexander.sverdlin@siemens.com>
> > >
> > > Enable/disable seems to be racy on SMP, consider the following scenario:
> > >
> > > CPU0 CPU1
> > >
> > > interrupt_cnt_enable_write(true)
> > > {
> > > if (priv->enabled == enable)
> > > return 0;
> > >
> > > if (enable) {
> > > priv->enabled = true;
> > > interrupt_cnt_enable_write(false)
> > > {
> > > if (priv->enabled == enable)
> > > return 0;
> > >
> > > if (enable) {
> > > priv->enabled = true;
> > > enable_irq(priv->irq);
> > > } else {
> > > disable_irq(priv->irq)
> > > priv->enabled = false;
> > > }
> > > enable_irq(priv->irq);
> > > } else {
> > > disable_irq(priv->irq);
> > > priv->enabled = false;
> > > }
> > >
> > > The above would result in priv->enabled == false, but IRQ left enabled.
> > > Protect both write (above race) and read (to propagate the value on SMP)
> > > callbacks with a mutex.
> > >
> > > Signed-off-by: Alexander Sverdlin <alexander.sverdlin@siemens.com>
> >
> > I've noticed that the patch has been marked as "Changes Requested" in
> > the patchwork, could it be a mistake? Because I never received any
> > change request.
>
> Hi Alexander,
>
> I can't comment on the patchwork status because I don't use that
> service, but I apologize nonetheless for the delay in responding to your
> patch submission. I'm hoping for an Ack from Oleksij, but this is a
> pretty straight-forward fix that I'll be happy to pick it up regardless.
>
> Would you provide a Fixes line so the stable trees can pick this up for
> the necessary kernel versions?
shall I re-spin or would this separate tag suffice?
Fixes: a55ebd47f21f ("counter: add IRQ or GPIO based counter")
--
Alexander Sverdlin
Siemens AG
www.siemens.com
next prev parent reply other threads:[~2025-05-02 16:32 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-03-31 16:36 [PATCH] counter: interrupt-cnt: Protect enable/disable OPs with mutex A. Sverdlin
2025-04-01 4:50 ` Ahmad Fatoum
2025-04-01 8:38 ` Sverdlin, Alexander
2025-04-01 8:42 ` Ahmad Fatoum
2025-05-02 9:24 ` Sverdlin, Alexander
2025-05-02 11:43 ` William Breathitt Gray
2025-05-02 11:50 ` Oleksij Rempel
2025-05-02 12:06 ` William Breathitt Gray
2025-05-02 16:32 ` Sverdlin, Alexander [this message]
2025-05-02 23:47 ` William Breathitt Gray
2025-05-02 23:49 ` William Breathitt Gray
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=f1e4a1db585e58aca766d0f48ebce3a28986944f.camel@siemens.com \
--to=alexander.sverdlin@siemens.com \
--cc=kernel@pengutronix.de \
--cc=linux-iio@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=o.rempel@pengutronix.de \
--cc=wbg@kernel.org \
/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