diff options
| -rw-r--r-- | drivers/i2c/algos/i2c-algo-pca.c | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/drivers/i2c/algos/i2c-algo-pca.c b/drivers/i2c/algos/i2c-algo-pca.c index cc3a952401..ff2db0da44 100644 --- a/drivers/i2c/algos/i2c-algo-pca.c +++ b/drivers/i2c/algos/i2c-algo-pca.c | |||
| @@ -187,12 +187,14 @@ static int pca_xfer(struct i2c_adapter *i2c_adap, | |||
| 187 | int numbytes = 0; | 187 | int numbytes = 0; |
| 188 | int state; | 188 | int state; |
| 189 | int ret; | 189 | int ret; |
| 190 | int timeout = 100; | ||
| 190 | 191 | ||
| 191 | state = pca_status(adap); | 192 | while ((state = pca_status(adap)) != 0xf8 && timeout--) { |
| 192 | if ( state != 0xF8 ) { | 193 | msleep(10); |
| 193 | dev_dbg(&i2c_adap->dev, "bus is not idle. status is %#04x\n", state ); | 194 | } |
| 194 | /* FIXME: what to do. Force stop ? */ | 195 | if (state != 0xf8) { |
| 195 | return -EREMOTEIO; | 196 | dev_dbg(&i2c_adap->dev, "bus is not idle. status is %#04x\n", state); |
| 197 | return -EIO; | ||
| 196 | } | 198 | } |
| 197 | 199 | ||
| 198 | DEB1("{{{ XFER %d messages\n", num); | 200 | DEB1("{{{ XFER %d messages\n", num); |
