Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 333391
b: refs/heads/master
c: b07be0f
h: refs/heads/master
i:
  333389: 47ab663
  333387: 6dc841a
  333383: e9c95ac
  333375: 5b0e89b
v: v3
  • Loading branch information
Felipe Balbi authored and Wolfram Sang committed Sep 12, 2012
1 parent 7756e5b commit 9abd38e
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 4 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: dd74548ddece4b9d68e5528287a272fa552c81d0
refs/heads/master: b07be0f3b9e1bed6cbd29117d7f0519d114fbd82
16 changes: 13 additions & 3 deletions trunk/drivers/i2c/busses/i2c-omap.c
Original file line number Diff line number Diff line change
Expand Up @@ -775,6 +775,17 @@ static int errata_omap3_i462(struct omap_i2c_dev *dev)
if (stat & (OMAP_I2C_STAT_NACK | OMAP_I2C_STAT_AL)) {
omap_i2c_ack_stat(dev, (OMAP_I2C_STAT_XRDY |
OMAP_I2C_STAT_XDR));
if (stat & OMAP_I2C_STAT_NACK) {
dev->cmd_err |= OMAP_I2C_STAT_NACK;
omap_i2c_ack_stat(dev, OMAP_I2C_STAT_NACK);
}

if (stat & OMAP_I2C_STAT_AL) {
dev_err(dev->dev, "Arbitration lost\n");
dev->cmd_err |= OMAP_I2C_STAT_AL;
omap_i2c_ack_stat(dev, OMAP_I2C_STAT_NACK);
}

return -EIO;
}

Expand Down Expand Up @@ -875,7 +886,6 @@ omap_i2c_isr(int this_irq, void *dev_id)
goto out;
}

complete:
if (stat & OMAP_I2C_STAT_NACK) {
err |= OMAP_I2C_STAT_NACK;
omap_i2c_ack_stat(dev, OMAP_I2C_STAT_NACK);
Expand Down Expand Up @@ -938,7 +948,7 @@ omap_i2c_isr(int this_irq, void *dev_id)
ret = omap_i2c_transmit_data(dev, num_bytes, true);
stat = omap_i2c_read_reg(dev, OMAP_I2C_STAT_REG);
if (ret < 0)
goto complete;
goto out;

omap_i2c_ack_stat(dev, OMAP_I2C_STAT_XDR);
continue;
Expand All @@ -954,7 +964,7 @@ omap_i2c_isr(int this_irq, void *dev_id)
ret = omap_i2c_transmit_data(dev, num_bytes, false);
stat = omap_i2c_read_reg(dev, OMAP_I2C_STAT_REG);
if (ret < 0)
goto complete;
goto out;

omap_i2c_ack_stat(dev, OMAP_I2C_STAT_XRDY);
continue;
Expand Down

0 comments on commit 9abd38e

Please sign in to comment.