aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSebastian Andrzej Siewior <bigeasy@linutronix.de>2011-02-23 06:38:19 -0500
committerBen Dooks <ben-linux@fluff.org>2011-03-21 05:23:55 -0400
commit93c92cfdec8c3f8764894b37606c174f68fd9338 (patch)
tree131888459d95f1139685e8c5b3f8ac30c7215d47
parentc66dc529194be374556d166ee7ddb84a7d1d302b (diff)
i2c-pxa2xx: check timeout correctly
timeout here maybe 0 if the event occured and a task with a higher priority stole the cpu and we were sleeping longer than the timeout value we specified. In case of a real timeout I changed the error code to I2C_RETRY so we retry the transfer. Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de> Signed-off-by: Dirk Brandewie <dirk.brandewie@gmail.com> Signed-off-by: Ben Dooks <ben-linux@fluff.org>
-rw-r--r--drivers/i2c/busses/i2c-pxa.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/i2c/busses/i2c-pxa.c b/drivers/i2c/busses/i2c-pxa.c
index fa8dd2c634d9..86128363a57f 100644
--- a/drivers/i2c/busses/i2c-pxa.c
+++ b/drivers/i2c/busses/i2c-pxa.c
@@ -770,8 +770,10 @@ static int i2c_pxa_do_xfer(struct pxa_i2c *i2c, struct i2c_msg *msg, int num)
770 */ 770 */
771 ret = i2c->msg_idx; 771 ret = i2c->msg_idx;
772 772
773 if (timeout == 0) 773 if (!timeout && i2c->msg_num) {
774 i2c_pxa_scream_blue_murder(i2c, "timeout"); 774 i2c_pxa_scream_blue_murder(i2c, "timeout");
775 ret = I2C_RETRY;
776 }
775 777
776 out: 778 out:
777 return ret; 779 return ret;