lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <CAHfa7xVxG48_qBXE8JcSNJgO1SG=Ge9qAyaCk2WLTvrKoH3NbQ@mail.gmail.com>
Date: Tue, 2 Dec 2025 12:54:44 +0100
From: Amin <amin.gattout@...il.com>
To: Eugen Hristev <eugen.hristev@...aro.org>
Cc: vkoul@...nel.org, thomasandreatta2000@...il.com, dmaengine@...r.kernel.org, 
	linux-kernel@...r.kernel.org
Subject: Re: [PATCH] shdmac: Remove misleading TODO comment in dmae_set_chcr

Thanks Eugen,

I could not reproduce any concrete issue, and after re-reading the
flow I think your assessment is correct:
If the channel is busy, CHCR is indeed never written, so in that sense
the TODO comment was accurate.

Given this, removing the busy check seems more consistent than
removing the comment...
My patch was therefore not addressing the real problem, sorry for the noise.

If you agree, I can prepare a follow-up patch that removes
the`dmae_is_busy()` check, or leave things as they are if that is
preferred.

Amin


Le mar. 2 déc. 2025 à 11:12, Eugen Hristev <eugen.hristev@...aro.org> a écrit :
>
>
>
> On 11/28/25 17:29, Amin GATTOUT wrote:
> > The comment suggested that the dmae_is_busy() check in dmae_set_chcr()
> > is superfluous and could be removed. However, this check serves as an
> > important safety net to prevent configuration of a DMA channel while
>
> I find this a bit odd overall, because apparently nobody checks the
> result of dmae_set_chcr() .
> So if it is such an important safety check, why is the result never
> checked ?
> As it looks, the caller doesn't care and continue as usual. The
> difference would be that chcr is never actually written if the channel
> is busy. Which looks strange. And "unexpected hardware behavior in edge
> cases" is quite vague. Do you have a scenario when an issue would happen ?
> dmae_set_chcr() gets called on resume() and setup_xfer(). Is it possible
> that in fact dmae_set_chcr() is not called correctly then ? Maybe this
> chcr should be written at a different time when we are sure the dma is
> not busy ?
> Or why is it even possible to have the dma busy when calling it ?
>
> Eugen
>
> > it is active. Keeping it helps ensure transfer integrity and avoids
> > unexpected hardware behavior in edge cases.
> >
> > Signed-off-by: Amin GATTOUT <amin.gattout@...il.com>
> > ---
> >  drivers/dma/sh/shdmac.c | 1 -
> >  1 file changed, 1 deletion(-)
> >
> > diff --git a/drivers/dma/sh/shdmac.c b/drivers/dma/sh/shdmac.c
> > index 603e15102e45..d0e0437ad916 100644
> > --- a/drivers/dma/sh/shdmac.c
> > +++ b/drivers/dma/sh/shdmac.c
> > @@ -243,7 +243,6 @@ static void dmae_init(struct sh_dmae_chan *sh_chan)
> >
> >  static int dmae_set_chcr(struct sh_dmae_chan *sh_chan, u32 val)
> >  {
> > -     /* If DMA is active, cannot set CHCR. TODO: remove this superfluous check */
> >       if (dmae_is_busy(sh_chan))
> >               return -EBUSY;
> >
>

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ