Commit a37791c5 authored by Devin Heitmueller's avatar Devin Heitmueller Committed by Mauro Carvalho Chehab

V4L/DVB (11804): xc5000: poll at 5ms interval for register write command completion

Instead of polling at 100ms intervals for register writes, poll at 5ms
intervals.  This is consistent with the xc5000 specification, and improves
tuning time by up to 500 ms on devices that such as the au0828 which do not
properly implement i2c clock stretching (since the five register writes that
occur for a tuning request often do not complete immediately but do complete
far before 100ms has gone by).

The net amount of time we wait before timing out is unchanged (500ms).
Signed-off-by: default avatarDevin Heitmueller <dheitmueller@kernellabs.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent 6c99080d
...@@ -262,7 +262,7 @@ static int xc5000_TunerReset(struct dvb_frontend *fe) ...@@ -262,7 +262,7 @@ static int xc5000_TunerReset(struct dvb_frontend *fe)
static int xc_write_reg(struct xc5000_priv *priv, u16 regAddr, u16 i2cData) static int xc_write_reg(struct xc5000_priv *priv, u16 regAddr, u16 i2cData)
{ {
u8 buf[4]; u8 buf[4];
int WatchDogTimer = 5; int WatchDogTimer = 100;
int result; int result;
buf[0] = (regAddr >> 8) & 0xFF; buf[0] = (regAddr >> 8) & 0xFF;
...@@ -284,7 +284,7 @@ static int xc_write_reg(struct xc5000_priv *priv, u16 regAddr, u16 i2cData) ...@@ -284,7 +284,7 @@ static int xc_write_reg(struct xc5000_priv *priv, u16 regAddr, u16 i2cData)
/* busy flag cleared */ /* busy flag cleared */
break; break;
} else { } else {
xc_wait(100); /* wait 5 ms */ xc_wait(5); /* wait 5 ms */
WatchDogTimer--; WatchDogTimer--;
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment