|
@@ -187,12 +187,14 @@ static int pca_xfer(struct i2c_adapter *i2c_adap,
|
|
|
int numbytes = 0;
|
|
|
int state;
|
|
|
int ret;
|
|
|
+ int timeout = 100;
|
|
|
|
|
|
- state = pca_status(adap);
|
|
|
- if ( state != 0xF8 ) {
|
|
|
- dev_dbg(&i2c_adap->dev, "bus is not idle. status is %#04x\n", state );
|
|
|
- /* FIXME: what to do. Force stop ? */
|
|
|
- return -EREMOTEIO;
|
|
|
+ while ((state = pca_status(adap)) != 0xf8 && timeout--) {
|
|
|
+ msleep(10);
|
|
|
+ }
|
|
|
+ if (state != 0xf8) {
|
|
|
+ dev_dbg(&i2c_adap->dev, "bus is not idle. status is %#04x\n", state);
|
|
|
+ return -EIO;
|
|
|
}
|
|
|
|
|
|
DEB1("{{{ XFER %d messages\n", num);
|