summaryrefslogtreecommitdiff
path: root/linux/drivers
diff options
context:
space:
mode:
authorDevin Heitmueller <dheitmueller@linuxtv.org>2009-03-11 02:00:41 -0400
committerDevin Heitmueller <dheitmueller@linuxtv.org>2009-03-11 02:00:41 -0400
commit1ea9fbb3a817b7afd092a07f301699fe53a1d4d6 (patch)
tree4be0a7bd1e3c2e7f79d0649a864a643d4c0cb143 /linux/drivers
parent785193038155c17372457bbf37b241b4893f9698 (diff)
downloadmediapointer-dvb-s2-1ea9fbb3a817b7afd092a07f301699fe53a1d4d6.tar.gz
mediapointer-dvb-s2-1ea9fbb3a817b7afd092a07f301699fe53a1d4d6.tar.bz2
au0828: workaround a bug in the au0828 i2c handling
From: Devin Heitmueller <dheitmueller@linuxtv.org> There is an issue related to the i2c clock for addressing the xc5000. The au0828 chip does not support clock stretching, which the xc5000 makes use of. This results in cases where we silently get back garbage in i2c read operations. To work around this issue until we slow down the i2c clock when talking with that specific device. This was not an issue before we had analog support because we never needed to enumerate the i2c bus, and digital tuning never actually needed to perform read operations against the xc5000. Thanks to Michael Krufky <mkrufky@linuxtv.org> and Steven Toth <stoth@linuxtv.org> for providing sample hardware, engineering level support, and testing. Priority: normal Signed-off-by: Devin Heitmueller <dheitmueller@linuxtv.org>
Diffstat (limited to 'linux/drivers')
-rw-r--r--linux/drivers/media/video/au0828/au0828-i2c.c22
1 files changed, 20 insertions, 2 deletions
diff --git a/linux/drivers/media/video/au0828/au0828-i2c.c b/linux/drivers/media/video/au0828/au0828-i2c.c
index d8cef6ccc..243e98b1d 100644
--- a/linux/drivers/media/video/au0828/au0828-i2c.c
+++ b/linux/drivers/media/video/au0828/au0828-i2c.c
@@ -141,7 +141,16 @@ static int i2c_sendbytes(struct i2c_adapter *i2c_adap,
dprintk(4, "%s()\n", __func__);
au0828_write(dev, REG_2FF, 0x01);
- au0828_write(dev, REG_202, 0x07);
+
+ /* FIXME: There is a problem with i2c communications with xc5000 that
+ requires us to slow down the i2c clock until we have a better
+ strategy (such as using the secondary i2c bus to do firmware
+ loading */
+ if ((msg->addr << 1) == 0xc2) {
+ au0828_write(dev, REG_202, 0x40);
+ } else {
+ au0828_write(dev, REG_202, 0x07);
+ }
/* Hardware needs 8 bit addresses */
au0828_write(dev, REG_203, msg->addr << 1);
@@ -192,7 +201,16 @@ static int i2c_readbytes(struct i2c_adapter *i2c_adap,
dprintk(4, "%s()\n", __func__);
au0828_write(dev, REG_2FF, 0x01);
- au0828_write(dev, REG_202, 0x07);
+
+ /* FIXME: There is a problem with i2c communications with xc5000 that
+ requires us to slow down the i2c clock until we have a better
+ strategy (such as using the secondary i2c bus to do firmware
+ loading */
+ if ((msg->addr << 1) == 0xc2) {
+ au0828_write(dev, REG_202, 0x40);
+ } else {
+ au0828_write(dev, REG_202, 0x07);
+ }
/* Hardware needs 8 bit addresses */
au0828_write(dev, REG_203, msg->addr << 1);