summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorEnrik Berkhan <Enrik.Berkhan@ge.com>2009-05-05 08:39:25 +0200
committerJean Delvare <khali@linux-fr.org>2009-05-05 08:39:25 +0200
commit2196d1cf4afab93fb64c2e5b417096e49b661612 (patch)
treeb9534b056eeb3a2e43620ef8ea52dd519ba50ba6 /lib
parent0cdba07bb23cdd3e0d64357ec3d983e6b75e541f (diff)
downloadop-kernel-dev-2196d1cf4afab93fb64c2e5b417096e49b661612.zip
op-kernel-dev-2196d1cf4afab93fb64c2e5b417096e49b661612.tar.gz
i2c-algo-pca: Let PCA9564 recover from unacked data byte (state 0x30)
Currently, the i2c-algo-pca driver does nothing if the chip enters state 0x30 (Data byte in I2CDAT has been transmitted; NOT ACK has been received). Thus, the i2c bus connected to the controller gets stuck afterwards. I have seen this kind of error on a custom board in certain load situations most probably caused by interference or noise. A possible reaction is to let the controller generate a STOP condition. This is documented in the PCA9564 data sheet (2006-09-01) and the same is done for other NACK states as well. Further, state 0x38 isn't handled completely, either. Try to do another START in this case like the data sheet says. As this couldn't be tested, I've added a comment to try to reset the chip if the START doesn't help as suggested by Wolfram Sang. Signed-off-by: Enrik Berkhan <Enrik.Berkhan@ge.com> Reviewed-by: Wolfram Sang <w.sang@pengutronix.de> Signed-off-by: Jean Delvare <khali@linux-fr.org>
Diffstat (limited to 'lib')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud