Commit 28c0a843 authored by Eddie Huang's avatar Eddie Huang Committed by Wolfram Sang

i2c: mediatek: Fixup i2c ack error interrupt handling

When occur i2c ack error, i2c controller generate two interrupts,
first is the ack error interrupt, then the complete interrupt.
i2c interrupt handler should keep the two interrupt value, and only
call complete() for the complete interrupt.
Signed-off-by: default avatarLiguo Zhang <liguo.zhang@mediatek.com>
Signed-off-by: default avatarEddie Huang <eddie.huang@mediatek.com>
Reviewed-by: default avatarDaniel Kurtz <djkurtz@chromium.org>
Signed-off-by: default avatarWolfram Sang <wsa@the-dreams.de>
parent ea89ef1f
...@@ -557,14 +557,21 @@ static irqreturn_t mtk_i2c_irq(int irqno, void *dev_id) ...@@ -557,14 +557,21 @@ static irqreturn_t mtk_i2c_irq(int irqno, void *dev_id)
{ {
struct mtk_i2c *i2c = dev_id; struct mtk_i2c *i2c = dev_id;
u16 restart_flag = 0; u16 restart_flag = 0;
u16 intr_stat;
if (i2c->dev_comp->auto_restart) if (i2c->dev_comp->auto_restart)
restart_flag = I2C_RS_TRANSFER; restart_flag = I2C_RS_TRANSFER;
i2c->irq_stat = readw(i2c->base + OFFSET_INTR_STAT); intr_stat = readw(i2c->base + OFFSET_INTR_STAT);
writew(restart_flag | I2C_HS_NACKERR | I2C_ACKERR writew(intr_stat, i2c->base + OFFSET_INTR_STAT);
| I2C_TRANSAC_COMP, i2c->base + OFFSET_INTR_STAT);
/*
* when occurs ack error, i2c controller generate two interrupts
* first is the ack error interrupt, then the complete interrupt
* i2c->irq_stat need keep the two interrupt value.
*/
i2c->irq_stat |= intr_stat;
if (i2c->irq_stat & (I2C_TRANSAC_COMP | restart_flag))
complete(&i2c->msg_complete); complete(&i2c->msg_complete);
return IRQ_HANDLED; return IRQ_HANDLED;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment