From: Lee Jones <lee@kernel.org>
To: Oliver Hartkopp <socketcan@hartkopp.net>
Cc: Marc Kleine-Budde <mkl@pengutronix.de>,
linux-can@vger.kernel.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH 1/1] can: bcm: prevent thrtimer UAF in rx path by checking RX_NO_AUTOTIMER
Date: Mon, 27 Apr 2026 13:40:58 +0100 [thread overview]
Message-ID: <20260427124058.GA8212@google.com> (raw)
In-Reply-To: <eef6917f-38c2-4bb4-a5d6-98f5a71adf65@hartkopp.net>
On Sat, 25 Apr 2026, Oliver Hartkopp wrote:
>
>
> On 24.04.26 21:08, Marc Kleine-Budde wrote:
> > On 22.04.2026 14:55:50, Oliver Hartkopp wrote:
> > >
> > >
> > > On 22.04.26 12:22, Lee Jones wrote:
> > > > Commit f1b4e32aca08 ("can: bcm: use call_rcu() instead of costly
> > > > synchronize_rcu()") removed the synchronize_rcu() call from
> > > > bcm_delete_rx_op() and introduced the RX_NO_AUTOTIMER flag to prevent
> > > > timers from being rearmed during deletion. However, it only applied
> > > > this check to op->timer via bcm_rx_starttimer().
> > > >
> > > > It missed the fact that op->thrtimer can also be rearmed by an
> > > > in-flight bcm_rx_handler() (which runs as an RCU reader) via
> > > > bcm_rx_update_and_send(). This allows op->thrtimer to be queued after
> > > > bcm_remove_op() has already cancelled it, leading to a use-after-free
> > > > when the timer fires on the deferred-freed struct bcm_op.
> > > >
> > > > Address the omission by checking the RX_NO_AUTOTIMER flag
> > > > in bcm_rx_update_and_send() before starting op->thrtimer, effectively
> > > > preventing it from being rearmed concurrently with teardown.
> > > >
> > > > Signed-off-by: Lee Jones <lee@kernel.org>
> > >
> > > Many thanks for the investigation and the fix!
> > >
> > > Acked-by: Oliver Hartkopp <socketcan@hartkopp.net>
> >
> > Can we add a Fixes: tag?
Fixes: f1b4e32aca08 ("can: bcm: use call_rcu() instead of costly synchronize_rcu()")
Do you need me to resubmit or are you okay to apply manually / with b4?
> Yes, we should.
>
> Thanks!
>
> Signed-off-by: Oliver Hartkopp <socketcan@hartkopp.net>
I'm a little confused by the SoB. Does this mean you've applied it?
--
Lee Jones
next prev parent reply other threads:[~2026-04-27 12:41 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-04-22 10:22 [PATCH 1/1] can: bcm: prevent thrtimer UAF in rx path by checking RX_NO_AUTOTIMER Lee Jones
2026-04-22 12:55 ` Oliver Hartkopp
2026-04-24 19:08 ` Marc Kleine-Budde
2026-04-25 6:49 ` Oliver Hartkopp
2026-04-27 12:40 ` Lee Jones [this message]
2026-04-27 17:15 ` Oliver Hartkopp
2026-04-27 17:41 ` Marc Kleine-Budde
2026-04-27 17:58 ` Oliver Hartkopp
2026-04-28 8:57 ` Lee Jones
2026-04-28 9:32 ` Oliver Hartkopp
2026-05-05 14:42 ` Lee Jones
2026-05-06 12:45 ` Marc Kleine-Budde
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=20260427124058.GA8212@google.com \
--to=lee@kernel.org \
--cc=linux-can@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mkl@pengutronix.de \
--cc=socketcan@hartkopp.net \
/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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.