[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <aa352b5c65459d4ca35c2ed48afa611839f4b2a3.camel@v3.sk>
Date: Fri, 16 Nov 2018 16:35:05 +0100
From: Lubomir Rintel <lkundrak@...sk>
To: Tony Lindgren <tony@...mide.com>, Mark Brown <broonie@...nel.org>
Cc: Geert Uytterhoeven <geert+renesas@...der.be>,
Pavel Machek <pavel@....cz>, linux-kernel@...r.kernel.org,
linux-arm-kernel@...ts.infradead.org, linux-omap@...r.kernel.org
Subject: Re: Regression in next with spi return from transfer_one()
On Thu, 2018-11-15 at 16:07 -0800, Tony Lindgren wrote:
> * Mark Brown <broonie@...nel.org> [181116 00:02]:
> > On Thu, Nov 15, 2018 at 03:44:00PM -0800, Tony Lindgren wrote:
> >
> > > It seems to be caused because of the now missing "if (ret > 0) {"
> > > line somehow that was there earlier. New code sets ms to 200 it
> > > seems, then dmesg shows:
> >
> > Doh, of course :( Sorry I missed that.
> >
> > > The old code is not updating ms and it's set to 1.
> >
> > Right, and not waiting either which should be the issue. Does the
> > following work:
>
> And it's recalculating the timeout every time now too :) Yup that
> fix works and the problem makes sense now:
>
> Tested-by: Tony Lindgren <tony@...mide.com>
My bad obviously. Sorry.
I'm grateful that you identified and fixed the problem so quickly.
Thanks,
Lubo
>
> > diff --git a/drivers/spi/spi.c b/drivers/spi/spi.c
> > index 498d3b9bf3ae..430ad637c643 100644
> > --- a/drivers/spi/spi.c
> > +++ b/drivers/spi/spi.c
> > @@ -1114,9 +1114,11 @@ static int spi_transfer_one_message(struct
> > spi_controller *ctlr,
> > goto out;
> > }
> >
> > - ret = spi_transfer_wait(ctlr, msg, xfer);
> > - if (ret < 0)
> > - msg->status = ret;
> > + if (ret > 0) {
> > + ret = spi_transfer_wait(ctlr, msg,
> > xfer);
> > + if (ret < 0)
> > + msg->status = ret;
> > + }
> > } else {
> > if (xfer->len)
> > dev_err(&msg->spi->dev,
>
>
Powered by blists - more mailing lists