Skip to content

Commit

Permalink
i2c-algo-pcf: Handle timeout correctly
Browse files Browse the repository at this point in the history
With a postfix decrement these timeouts reach -1 rather than 0, but after the
loop it is tested whether they have become 0.

As pointed out by Jean Delvare, the msg_num should be tested before the timeout.
With the current order, you could exit with a timeout error while all the
messages were successfully transferred.

Signed-off-by: Roel Kluin <roel.kluin@gmail.com>
Signed-off-by: Jean Delvare <khali@linux-fr.org>
Acked-by: Eric Brower <ebrower@gmail.com>
  • Loading branch information
Roel Kluin authored and Jean Delvare committed Mar 28, 2009
1 parent 0c168ce commit 94d78e1
Showing 1 changed file with 10 additions and 8 deletions.
18 changes: 10 additions & 8 deletions drivers/i2c/algos/i2c-algo-pcf.c
Original file line number Diff line number Diff line change
Expand Up @@ -115,15 +115,17 @@ static int wait_for_bb(struct i2c_algo_pcf_data *adap)

status = get_pcf(adap, 1);

while (timeout-- && !(status & I2C_PCF_BB)) {
while (!(status & I2C_PCF_BB) && --timeout) {
udelay(100); /* wait for 100 us */
status = get_pcf(adap, 1);
}

if (timeout <= 0)
if (timeout == 0) {
printk(KERN_ERR "Timeout waiting for Bus Busy\n");
return -ETIMEDOUT;
}

return timeout <= 0;
return 0;
}

static int wait_for_pin(struct i2c_algo_pcf_data *adap, int *status)
Expand All @@ -133,7 +135,7 @@ static int wait_for_pin(struct i2c_algo_pcf_data *adap, int *status)

*status = get_pcf(adap, 1);

while (timeout-- && (*status & I2C_PCF_PIN)) {
while ((*status & I2C_PCF_PIN) && --timeout) {
adap->waitforpin(adap->data);
*status = get_pcf(adap, 1);
}
Expand All @@ -142,10 +144,10 @@ static int wait_for_pin(struct i2c_algo_pcf_data *adap, int *status)
return -EINTR;
}

if (timeout <= 0)
return -1;
else
return 0;
if (timeout == 0)
return -ETIMEDOUT;

return 0;
}

/*
Expand Down

0 comments on commit 94d78e1

Please sign in to comment.