i2c: riic: Clear NACK in tend isr
The NACKF flag should be cleared in INTRIICNAKI interrupt processing as
description in HW manual.
This issue shows up quickly when PREEMPT_RT is applied and a device is
probed that is not plugged in (like a touchscreen controller). The result
is endless interrupts that halt system boot.
Fixes: 310c18a414
("i2c: riic: add driver")
Cc: stable@vger.kernel.org
Reported-by: Chien Nguyen <chien.nguyen.eb@rvc.renesas.com>
Signed-off-by: Chris Brandt <chris.brandt@renesas.com>
Signed-off-by: Wolfram Sang <wsa@the-dreams.de>
This commit is contained in:
parent
127068abe8
commit
a71e2ac1f3
|
@ -202,6 +202,7 @@ static irqreturn_t riic_tend_isr(int irq, void *data)
|
||||||
if (readb(riic->base + RIIC_ICSR2) & ICSR2_NACKF) {
|
if (readb(riic->base + RIIC_ICSR2) & ICSR2_NACKF) {
|
||||||
/* We got a NACKIE */
|
/* We got a NACKIE */
|
||||||
readb(riic->base + RIIC_ICDRR); /* dummy read */
|
readb(riic->base + RIIC_ICDRR); /* dummy read */
|
||||||
|
riic_clear_set_bit(riic, ICSR2_NACKF, 0, RIIC_ICSR2);
|
||||||
riic->err = -ENXIO;
|
riic->err = -ENXIO;
|
||||||
} else if (riic->bytes_left) {
|
} else if (riic->bytes_left) {
|
||||||
return IRQ_NONE;
|
return IRQ_NONE;
|
||||||
|
|
Loading…
Reference in New Issue