* [PATCH] i2c: rk3x: fix bug that cause transfer fails in master receive mode @ 2014-08-21 17:50 Addy Ke 2014-08-21 18:04 ` Sergei Shtylyov 0 siblings, 1 reply; 5+ messages in thread From: Addy Ke @ 2014-08-21 17:50 UTC (permalink / raw) To: wsa, max.schwarz, heiko, olof, dianders Cc: linux-i2c, linux-kernel, linux-arm-kernel, linux-rockchip, cf, xjq, huangtao, zyw, yzq, hj, kever.yang, hl, caesar.wang, zhengsq, Addy Ke In rk3x SOC, the I2C controller can receive/transmit up to 32 bytes data in one transaction, so the size of data to be write/read to/from TXDATAx/RXDATAx must be less than or equal 32 bytes at a time. Test on pinky board, elan receive 158 bytes data. Signed-off-by: Addy Ke <addy.ke@rock-chips.com> --- drivers/i2c/busses/i2c-rk3x.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/drivers/i2c/busses/i2c-rk3x.c b/drivers/i2c/busses/i2c-rk3x.c index 69e1185..dc0aa64 100644 --- a/drivers/i2c/busses/i2c-rk3x.c +++ b/drivers/i2c/busses/i2c-rk3x.c @@ -323,6 +323,9 @@ static void rk3x_i2c_handle_read(struct rk3x_i2c *i2c, unsigned int ipd) /* ack interrupt */ i2c_writel(i2c, REG_INT_MBRF, REG_IPD); + /* Can only handle a maximum of 32 bytes at a time */ + len = (len > 32) ? 32 : len; + /* read the data from receive buffer */ for (i = 0; i < len; ++i) { if (i % 4 == 0) -- 1.8.3.2 ^ permalink raw reply related [flat|nested] 5+ messages in thread
* Re: [PATCH] i2c: rk3x: fix bug that cause transfer fails in master receive mode 2014-08-21 17:50 [PATCH] i2c: rk3x: fix bug that cause transfer fails in master receive mode Addy Ke @ 2014-08-21 18:04 ` Sergei Shtylyov [not found] ` <53F634AF.1010303-M4DtvfQ/ZS1MRgGoP+s0PdBPR1lH4CV8@public.gmane.org> 0 siblings, 1 reply; 5+ messages in thread From: Sergei Shtylyov @ 2014-08-21 18:04 UTC (permalink / raw) To: Addy Ke, wsa, max.schwarz, heiko, olof, dianders Cc: huangtao, hl, yzq, zyw, linux-kernel, kever.yang, linux-rockchip, xjq, linux-i2c, caesar.wang, cf, hj, zhengsq, linux-arm-kernel Hello. On 08/21/2014 09:50 PM, Addy Ke wrote: > In rk3x SOC, the I2C controller can receive/transmit up to 32 bytes data > in one transaction, so the size of data to be write/read to/from > TXDATAx/RXDATAx must be less than or equal 32 bytes at a time. > Test on pinky board, elan receive 158 bytes data. > Signed-off-by: Addy Ke <addy.ke@rock-chips.com> > --- > drivers/i2c/busses/i2c-rk3x.c | 3 +++ > 1 file changed, 3 insertions(+) > diff --git a/drivers/i2c/busses/i2c-rk3x.c b/drivers/i2c/busses/i2c-rk3x.c > index 69e1185..dc0aa64 100644 > --- a/drivers/i2c/busses/i2c-rk3x.c > +++ b/drivers/i2c/busses/i2c-rk3x.c > @@ -323,6 +323,9 @@ static void rk3x_i2c_handle_read(struct rk3x_i2c *i2c, unsigned int ipd) > /* ack interrupt */ > i2c_writel(i2c, REG_INT_MBRF, REG_IPD); > > + /* Can only handle a maximum of 32 bytes at a time */ > + len = (len > 32) ? 32 : len; Why not min(len, 32)? Or even: if (len > 32) len = 32; WBR, Sergei ^ permalink raw reply [flat|nested] 5+ messages in thread
[parent not found: <53F634AF.1010303-M4DtvfQ/ZS1MRgGoP+s0PdBPR1lH4CV8@public.gmane.org>]
* Re: [PATCH] i2c: rk3x: fix bug that cause transfer fails in master receive mode [not found] ` <53F634AF.1010303-M4DtvfQ/ZS1MRgGoP+s0PdBPR1lH4CV8@public.gmane.org> @ 2014-08-21 18:17 ` Wolfram Sang 2014-08-21 18:54 ` Max Schwarz 0 siblings, 1 reply; 5+ messages in thread From: Wolfram Sang @ 2014-08-21 18:17 UTC (permalink / raw) To: Sergei Shtylyov Cc: Addy Ke, max.schwarz-BGeptl67XyCzQB+pC5nmwQ, heiko-4mtYJXux2i+zQB+pC5nmwQ, olof-nZhT3qVonbNeoWH0uzbU5w, dianders-F7+t8E8rja9g9hUCZPvPmw, huangtao-TNX95d0MmH7DzftRWevZcw, hl-TNX95d0MmH7DzftRWevZcw, yzq-TNX95d0MmH7DzftRWevZcw, zyw-TNX95d0MmH7DzftRWevZcw, linux-kernel-u79uwXL29TY76Z2rM5mHXA, kever.yang-TNX95d0MmH7DzftRWevZcw, linux-rockchip-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r, xjq-TNX95d0MmH7DzftRWevZcw, linux-i2c-u79uwXL29TY76Z2rM5mHXA, caesar.wang-TNX95d0MmH7DzftRWevZcw, cf-TNX95d0MmH7DzftRWevZcw, hj-TNX95d0MmH7DzftRWevZcw, zhengsq-TNX95d0MmH7DzftRWevZcw, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r [-- Attachment #1: Type: text/plain, Size: 1341 bytes --] On Thu, Aug 21, 2014 at 10:04:31PM +0400, Sergei Shtylyov wrote: > Hello. > > On 08/21/2014 09:50 PM, Addy Ke wrote: > > >In rk3x SOC, the I2C controller can receive/transmit up to 32 bytes data > >in one transaction, so the size of data to be write/read to/from > >TXDATAx/RXDATAx must be less than or equal 32 bytes at a time. > > >Test on pinky board, elan receive 158 bytes data. > > >Signed-off-by: Addy Ke <addy.ke-TNX95d0MmH7DzftRWevZcw@public.gmane.org> > >--- > > drivers/i2c/busses/i2c-rk3x.c | 3 +++ > > 1 file changed, 3 insertions(+) > > >diff --git a/drivers/i2c/busses/i2c-rk3x.c b/drivers/i2c/busses/i2c-rk3x.c > >index 69e1185..dc0aa64 100644 > >--- a/drivers/i2c/busses/i2c-rk3x.c > >+++ b/drivers/i2c/busses/i2c-rk3x.c > >@@ -323,6 +323,9 @@ static void rk3x_i2c_handle_read(struct rk3x_i2c *i2c, unsigned int ipd) > > /* ack interrupt */ > > i2c_writel(i2c, REG_INT_MBRF, REG_IPD); > > > >+ /* Can only handle a maximum of 32 bytes at a time */ > >+ len = (len > 32) ? 32 : len; > > Why not min(len, 32)? Or even: > > if (len > 32) > len = 32; No silent trimming, please. The message should be rejected when the transfer is set up. We could assign -EOVERFLOW to that type of failures, so users will know. Sadly, I have seen other controllers having such limits :( [-- Attachment #2: Digital signature --] [-- Type: application/pgp-signature, Size: 819 bytes --] ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] i2c: rk3x: fix bug that cause transfer fails in master receive mode 2014-08-21 18:17 ` Wolfram Sang @ 2014-08-21 18:54 ` Max Schwarz 2014-08-21 20:12 ` Wolfram Sang 0 siblings, 1 reply; 5+ messages in thread From: Max Schwarz @ 2014-08-21 18:54 UTC (permalink / raw) To: Wolfram Sang Cc: Sergei Shtylyov, Addy Ke, heiko-4mtYJXux2i+zQB+pC5nmwQ, olof-nZhT3qVonbNeoWH0uzbU5w, dianders-F7+t8E8rja9g9hUCZPvPmw, huangtao-TNX95d0MmH7DzftRWevZcw, hl-TNX95d0MmH7DzftRWevZcw, yzq-TNX95d0MmH7DzftRWevZcw, zyw-TNX95d0MmH7DzftRWevZcw, linux-kernel-u79uwXL29TY76Z2rM5mHXA, kever.yang-TNX95d0MmH7DzftRWevZcw, linux-rockchip-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r, xjq-TNX95d0MmH7DzftRWevZcw, linux-i2c-u79uwXL29TY76Z2rM5mHXA, caesar.wang-TNX95d0MmH7DzftRWevZcw, cf-TNX95d0MmH7DzftRWevZcw, hj-TNX95d0MmH7DzftRWevZcw, zhengsq-TNX95d0MmH7DzftRWevZcw, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r Hi, On Thursday 21 August 2014 at 13:17:38, Wolfram Sang wrote: > On Thu, Aug 21, 2014 at 10:04:31PM +0400, Sergei Shtylyov wrote: > > Hello. > > > > On 08/21/2014 09:50 PM, Addy Ke wrote: > > >In rk3x SOC, the I2C controller can receive/transmit up to 32 bytes data > > >in one transaction, so the size of data to be write/read to/from > > >TXDATAx/RXDATAx must be less than or equal 32 bytes at a time. > > > > > >Test on pinky board, elan receive 158 bytes data. > > > > > >Signed-off-by: Addy Ke <addy.ke-TNX95d0MmH7DzftRWevZcw@public.gmane.org> > > >--- > > > > > > drivers/i2c/busses/i2c-rk3x.c | 3 +++ > > > 1 file changed, 3 insertions(+) > > > > > >diff --git a/drivers/i2c/busses/i2c-rk3x.c > > >b/drivers/i2c/busses/i2c-rk3x.c > > >index 69e1185..dc0aa64 100644 > > >--- a/drivers/i2c/busses/i2c-rk3x.c > > >+++ b/drivers/i2c/busses/i2c-rk3x.c > > >@@ -323,6 +323,9 @@ static void rk3x_i2c_handle_read(struct rk3x_i2c > > >*i2c, unsigned int ipd)> > > > > /* ack interrupt */ > > > i2c_writel(i2c, REG_INT_MBRF, REG_IPD); > > > > > >+ /* Can only handle a maximum of 32 bytes at a time */ > > >+ len = (len > 32) ? 32 : len; > > > > > Why not min(len, 32)? Or even: > > if (len > 32) > > > > len = 32; > > No silent trimming, please. The message should be rejected when the transfer > is set up. We could assign -EOVERFLOW to that type of failures, so users > will know. Sadly, I have seen other controllers having such limits :( Actually, reads with >32 bytes of data are possible with the controller. The hw returns the data in 32 byte chunks. Our chunk handling code is just buggy. We always read the number of missing bytes from the current chunk, instead of truncating that to 32. The fix is correct. The following lines in the rk3x_i2c_handle_read() function already check if we got everything and trigger an additional chunk read if necessary: /* are we finished? */ if (i2c->processed == i2c->msg->len) rk3x_i2c_stop(i2c, i2c->error); else rk3x_i2c_prepare_read(i2c); I'd like a clearer syntax as suggested by Sergei, though. Apart from that, Acked-By: Max Schwarz <max.schwarz-BGeptl67XyCzQB+pC5nmwQ@public.gmane.org> Cheers, Max ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] i2c: rk3x: fix bug that cause transfer fails in master receive mode 2014-08-21 18:54 ` Max Schwarz @ 2014-08-21 20:12 ` Wolfram Sang 0 siblings, 0 replies; 5+ messages in thread From: Wolfram Sang @ 2014-08-21 20:12 UTC (permalink / raw) To: Max Schwarz Cc: Sergei Shtylyov, Addy Ke, heiko-4mtYJXux2i+zQB+pC5nmwQ, olof-nZhT3qVonbNeoWH0uzbU5w, dianders-F7+t8E8rja9g9hUCZPvPmw, huangtao-TNX95d0MmH7DzftRWevZcw, hl-TNX95d0MmH7DzftRWevZcw, yzq-TNX95d0MmH7DzftRWevZcw, zyw-TNX95d0MmH7DzftRWevZcw, linux-kernel-u79uwXL29TY76Z2rM5mHXA, kever.yang-TNX95d0MmH7DzftRWevZcw, linux-rockchip-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r, xjq-TNX95d0MmH7DzftRWevZcw, linux-i2c-u79uwXL29TY76Z2rM5mHXA, caesar.wang-TNX95d0MmH7DzftRWevZcw, cf-TNX95d0MmH7DzftRWevZcw, hj-TNX95d0MmH7DzftRWevZcw, zhengsq-TNX95d0MmH7DzftRWevZcw, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r [-- Attachment #1: Type: text/plain, Size: 256 bytes --] > Actually, reads with >32 bytes of data are possible with the controller. The > hw returns the data in 32 byte chunks. Our chunk handling code is just buggy. Understood. Then, I'd prefer 'chunk' in the commit message instead of 'transaction'. [-- Attachment #2: Digital signature --] [-- Type: application/pgp-signature, Size: 819 bytes --] ^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2014-08-21 20:12 UTC | newest] Thread overview: 5+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2014-08-21 17:50 [PATCH] i2c: rk3x: fix bug that cause transfer fails in master receive mode Addy Ke 2014-08-21 18:04 ` Sergei Shtylyov [not found] ` <53F634AF.1010303-M4DtvfQ/ZS1MRgGoP+s0PdBPR1lH4CV8@public.gmane.org> 2014-08-21 18:17 ` Wolfram Sang 2014-08-21 18:54 ` Max Schwarz 2014-08-21 20:12 ` Wolfram Sang
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).