diff options
author | Ben Dooks <ben-linux@fluff.org> | 2011-01-12 17:24:36 -0500 |
---|---|---|
committer | Ben Dooks <ben-linux@fluff.org> | 2011-01-12 17:24:36 -0500 |
commit | 7f42f9fef7bbc4f3250a33bf58170c640cd3db18 (patch) | |
tree | 1414676d0fa9a4d51bfb95bbb758f6141657f907 /drivers/i2c | |
parent | cc3feac34617ec685551905507cd8d909be6431f (diff) | |
parent | 6a91b558648cffa94227b4ff9c6c996930bbdfd2 (diff) |
Merge branch 'for-2638/i2c/omap' into for-linus/i2c-2638
Diffstat (limited to 'drivers/i2c')
-rw-r--r-- | drivers/i2c/busses/i2c-omap.c | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/drivers/i2c/busses/i2c-omap.c b/drivers/i2c/busses/i2c-omap.c index 9d090833e245..b605ff3a1fa0 100644 --- a/drivers/i2c/busses/i2c-omap.c +++ b/drivers/i2c/busses/i2c-omap.c | |||
@@ -598,12 +598,8 @@ static int omap_i2c_xfer_msg(struct i2c_adapter *adap, | |||
598 | * REVISIT: We should abort the transfer on signals, but the bus goes | 598 | * REVISIT: We should abort the transfer on signals, but the bus goes |
599 | * into arbitration and we're currently unable to recover from it. | 599 | * into arbitration and we're currently unable to recover from it. |
600 | */ | 600 | */ |
601 | if (dev->set_mpu_wkup_lat != NULL) | ||
602 | dev->set_mpu_wkup_lat(dev->dev, dev->latency); | ||
603 | r = wait_for_completion_timeout(&dev->cmd_complete, | 601 | r = wait_for_completion_timeout(&dev->cmd_complete, |
604 | OMAP_I2C_TIMEOUT); | 602 | OMAP_I2C_TIMEOUT); |
605 | if (dev->set_mpu_wkup_lat != NULL) | ||
606 | dev->set_mpu_wkup_lat(dev->dev, -1); | ||
607 | dev->buf_len = 0; | 603 | dev->buf_len = 0; |
608 | if (r < 0) | 604 | if (r < 0) |
609 | return r; | 605 | return r; |
@@ -654,12 +650,18 @@ omap_i2c_xfer(struct i2c_adapter *adap, struct i2c_msg msgs[], int num) | |||
654 | if (r < 0) | 650 | if (r < 0) |
655 | goto out; | 651 | goto out; |
656 | 652 | ||
653 | if (dev->set_mpu_wkup_lat != NULL) | ||
654 | dev->set_mpu_wkup_lat(dev->dev, dev->latency); | ||
655 | |||
657 | for (i = 0; i < num; i++) { | 656 | for (i = 0; i < num; i++) { |
658 | r = omap_i2c_xfer_msg(adap, &msgs[i], (i == (num - 1))); | 657 | r = omap_i2c_xfer_msg(adap, &msgs[i], (i == (num - 1))); |
659 | if (r != 0) | 658 | if (r != 0) |
660 | break; | 659 | break; |
661 | } | 660 | } |
662 | 661 | ||
662 | if (dev->set_mpu_wkup_lat != NULL) | ||
663 | dev->set_mpu_wkup_lat(dev->dev, -1); | ||
664 | |||
663 | if (r == 0) | 665 | if (r == 0) |
664 | r = num; | 666 | r = num; |
665 | 667 | ||