All of lore.kernel.org
 help / color / mirror / Atom feed
From: "Grygorii.Strashko@linaro.org" <grygorii.strashko@linaro.org>
To: Wolfram Sang <wsa@the-dreams.de>
Cc: "Sekhar Nori" <nsekhar@ti.com>,
	"Uwe Kleine-König" <u.kleine-koenig@pengutronix.de>,
	linux-i2c@vger.kernel.org, linux-arm-kernel@lists.infradead.org,
	linux-kernel@vger.kernel.org,
	"Kevin Hilman" <khilman@deeprootsystems.com>,
	"Santosh Shilimkar" <ssantosh@kernel.org>,
	"Murali Karicheri" <m-karicheri2@ti.com>,
	"Alexander Sverdlin" <alexander.sverdlin@nokia.com>
Subject: Re: [PATCH v3 4/5] i2c: davinci: use bus recovery infrastructure
Date: Fri, 20 Mar 2015 20:32:54 +0200	[thread overview]
Message-ID: <550C67D6.3080909@linaro.org> (raw)
In-Reply-To: <20150318203151.GA12072@katana>

Hi,
On 03/18/2015 10:31 PM, Wolfram Sang wrote:
> Hi,
> 
> so, the bus recovery patches look fine to me in general.
> 
> It is only this one question left which I always had with bus recovery.
> Maybe you guys can join me thinking about it.

Ok. Thanks and sorry for delayed reply - missed your e-mail :(
I'll resend them next week.

> 
>> @@ -376,8 +366,7 @@ i2c_davinci_xfer_msg(struct i2c_adapter *adap, struct i2c_msg *msg, int stop)
>>   						      dev->adapter.timeout);
>>   	if (r == 0) {
>>   		dev_err(dev->dev, "controller timed out\n");
>> -		davinci_i2c_recover_bus(dev);
>> -		i2c_davinci_init(dev);
>> +		i2c_recover_bus(adap);
>>   		dev->buf_len = 0;
>>   		return -ETIMEDOUT;
> 
> The I2C specs say in 3.1.16 that the recovery procedure should be used
> when SDA is stuck low. So, I do wonder if we should apply the recovery
> after a timeout. Stuck SDA might be one reason for timeout, but there
> may be others...

This is ancient code. And regarding your question -
Might be it would be reasonable to add call of
i2c_davinci_wait_bus_not_busy() at the end of i2c_davinci_xfer()?
This way we will wait for Bus Free before performing recovery.

Of course,  i2c_davinci_wait_bus_not_busy() has to be fixed first
as proposed by Alexander Sverdlin here:
 https://patchwork.ozlabs.org/patch/448994/. 

-- 
regards,
-grygorii

WARNING: multiple messages have this Message-ID (diff)
From: grygorii.strashko@linaro.org (Grygorii.Strashko@linaro.org)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH v3 4/5] i2c: davinci: use bus recovery infrastructure
Date: Fri, 20 Mar 2015 20:32:54 +0200	[thread overview]
Message-ID: <550C67D6.3080909@linaro.org> (raw)
In-Reply-To: <20150318203151.GA12072@katana>

Hi,
On 03/18/2015 10:31 PM, Wolfram Sang wrote:
> Hi,
> 
> so, the bus recovery patches look fine to me in general.
> 
> It is only this one question left which I always had with bus recovery.
> Maybe you guys can join me thinking about it.

Ok. Thanks and sorry for delayed reply - missed your e-mail :(
I'll resend them next week.

> 
>> @@ -376,8 +366,7 @@ i2c_davinci_xfer_msg(struct i2c_adapter *adap, struct i2c_msg *msg, int stop)
>>   						      dev->adapter.timeout);
>>   	if (r == 0) {
>>   		dev_err(dev->dev, "controller timed out\n");
>> -		davinci_i2c_recover_bus(dev);
>> -		i2c_davinci_init(dev);
>> +		i2c_recover_bus(adap);
>>   		dev->buf_len = 0;
>>   		return -ETIMEDOUT;
> 
> The I2C specs say in 3.1.16 that the recovery procedure should be used
> when SDA is stuck low. So, I do wonder if we should apply the recovery
> after a timeout. Stuck SDA might be one reason for timeout, but there
> may be others...

This is ancient code. And regarding your question -
Might be it would be reasonable to add call of
i2c_davinci_wait_bus_not_busy() at the end of i2c_davinci_xfer()?
This way we will wait for Bus Free before performing recovery.

Of course,  i2c_davinci_wait_bus_not_busy() has to be fixed first
as proposed by Alexander Sverdlin here:
 https://patchwork.ozlabs.org/patch/448994/. 

-- 
regards,
-grygorii

  reply	other threads:[~2015-03-20 18:32 UTC|newest]

Thread overview: 60+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-12-01 15:34 [PATCH v3 0/5] i2c: davinci improvements and fixes Grygorii Strashko
2014-12-01 15:34 ` Grygorii Strashko
2014-12-01 15:34 ` Grygorii Strashko
     [not found] ` <1417448047-15236-1-git-send-email-grygorii.strashko-l0cyMroinI0@public.gmane.org>
2014-12-01 15:34   ` [PATCH v3 1/5] i2c: i2c-davinci: switch to use platform_get_irq Grygorii Strashko
2014-12-01 15:34     ` Grygorii Strashko
2014-12-01 15:34     ` Grygorii Strashko
     [not found]     ` <1417448047-15236-2-git-send-email-grygorii.strashko-l0cyMroinI0@public.gmane.org>
2014-12-04 18:28       ` Wolfram Sang
2014-12-04 18:28         ` Wolfram Sang
2014-12-04 18:28         ` Wolfram Sang
2014-12-01 15:34 ` [PATCH v3 2/5] i2c: davinci: generate STP always when NACK is received Grygorii Strashko
2014-12-01 15:34   ` Grygorii Strashko
2014-12-01 15:34   ` Grygorii Strashko
2014-12-04 18:28   ` Wolfram Sang
2014-12-04 18:28     ` Wolfram Sang
2014-12-01 15:34 ` [PATCH v3 3/5] i2c: recovery: change input parameter to i2c_adapter for prepare/unprepare_recovery Grygorii Strashko
2014-12-01 15:34   ` Grygorii Strashko
2014-12-01 15:34   ` Grygorii Strashko
     [not found]   ` <1417448047-15236-4-git-send-email-grygorii.strashko-l0cyMroinI0@public.gmane.org>
2014-12-04 18:29     ` Wolfram Sang
2014-12-04 18:29       ` Wolfram Sang
2014-12-04 18:29       ` Wolfram Sang
2015-03-05 18:41       ` Grygorii Strashko
2015-03-05 18:41         ` Grygorii Strashko
2015-03-05 18:41         ` Grygorii Strashko
2015-03-12 11:32     ` Alexander Sverdlin
2015-03-12 11:32       ` Alexander Sverdlin
2015-03-12 11:32       ` Alexander Sverdlin
     [not found]       ` <55017943.6040603-xNZwKgViW5gAvxtiuMwx3w@public.gmane.org>
2015-03-13 10:15         ` Grygorii.Strashko-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org
2015-03-13 10:15           ` Grygorii.Strashko@linaro.org
2015-03-13 10:15           ` Grygorii.Strashko@linaro.org
     [not found]           ` <5502B8DA.70504-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org>
2015-03-13 15:45             ` Felipe Balbi
2015-03-13 15:45               ` Felipe Balbi
2015-03-13 15:45               ` Felipe Balbi
2014-12-01 15:34 ` [PATCH v3 4/5] i2c: davinci: use bus recovery infrastructure Grygorii Strashko
2014-12-01 15:34   ` Grygorii Strashko
2014-12-01 15:34   ` Grygorii Strashko
2015-03-12 11:45   ` Alexander Sverdlin
2015-03-12 11:45     ` Alexander Sverdlin
     [not found]   ` <1417448047-15236-5-git-send-email-grygorii.strashko-l0cyMroinI0@public.gmane.org>
2015-03-18 20:31     ` Wolfram Sang
2015-03-18 20:31       ` Wolfram Sang
2015-03-18 20:31       ` Wolfram Sang
2015-03-20 18:32       ` Grygorii.Strashko@linaro.org [this message]
2015-03-20 18:32         ` Grygorii.Strashko@linaro.org
     [not found]         ` <550C67D6.3080909-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org>
2015-04-03 20:18           ` Wolfram Sang
2015-04-03 20:18             ` Wolfram Sang
2015-04-03 20:18             ` Wolfram Sang
2015-04-06 13:11             ` Grygorii.Strashko-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org
2015-04-06 13:11               ` Grygorii.Strashko@linaro.org
2015-04-06 13:11               ` Grygorii.Strashko@linaro.org
     [not found]               ` <55228613.2060607-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org>
2015-04-06 16:09                 ` Wolfram Sang
2015-04-06 16:09                   ` Wolfram Sang
2015-04-06 16:09                   ` Wolfram Sang
2015-04-06 16:28                   ` Grygorii.Strashko-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org
2015-04-06 16:28                     ` Grygorii.Strashko@linaro.org
2015-04-06 16:28                     ` Grygorii.Strashko@linaro.org
2014-12-01 15:34 ` [PATCH 5/5] i2c: davinci: use ICPFUNC to toggle I2C as gpio for bus recovery Grygorii Strashko
2014-12-01 15:34   ` Grygorii Strashko
2014-12-01 15:34   ` Grygorii Strashko
     [not found]   ` <1417448047-15236-6-git-send-email-grygorii.strashko-l0cyMroinI0@public.gmane.org>
2015-04-01 14:38     ` Alexander Sverdlin
2015-04-01 14:38       ` Alexander Sverdlin
2015-04-01 14:38       ` Alexander Sverdlin

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=550C67D6.3080909@linaro.org \
    --to=grygorii.strashko@linaro.org \
    --cc=alexander.sverdlin@nokia.com \
    --cc=khilman@deeprootsystems.com \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-i2c@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=m-karicheri2@ti.com \
    --cc=nsekhar@ti.com \
    --cc=ssantosh@kernel.org \
    --cc=u.kleine-koenig@pengutronix.de \
    --cc=wsa@the-dreams.de \
    /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.