can: flexcan: Ack wakeup interrupt separately
As FLEXCAN_ESR_ALL_INT is for all bus errors and state change IRQ sources, strictly speaking FLEXCAN_ESR_WAK_INT does not belong to these. So add wakeup interrupt ack separately to existing ack of the interrupts. Suggested-by: Marc Kleine-Budde <mkl@pengutronix.de> Signed-off-by: Joakim Zhang <qiangqing.zhang@nxp.com> Link: https://lore.kernel.org/r/20191204113249.3381-3-qiangqing.zhang@nxp.com Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
This commit is contained in:
parent
ef4b623b14
commit
ab60523a76
|
@ -134,8 +134,7 @@
|
||||||
(FLEXCAN_ESR_ERR_BUS | FLEXCAN_ESR_ERR_STATE)
|
(FLEXCAN_ESR_ERR_BUS | FLEXCAN_ESR_ERR_STATE)
|
||||||
#define FLEXCAN_ESR_ALL_INT \
|
#define FLEXCAN_ESR_ALL_INT \
|
||||||
(FLEXCAN_ESR_TWRN_INT | FLEXCAN_ESR_RWRN_INT | \
|
(FLEXCAN_ESR_TWRN_INT | FLEXCAN_ESR_RWRN_INT | \
|
||||||
FLEXCAN_ESR_BOFF_INT | FLEXCAN_ESR_ERR_INT | \
|
FLEXCAN_ESR_BOFF_INT | FLEXCAN_ESR_ERR_INT)
|
||||||
FLEXCAN_ESR_WAK_INT)
|
|
||||||
|
|
||||||
/* FLEXCAN interrupt flag register (IFLAG) bits */
|
/* FLEXCAN interrupt flag register (IFLAG) bits */
|
||||||
/* Errata ERR005829 step7: Reserve first valid MB */
|
/* Errata ERR005829 step7: Reserve first valid MB */
|
||||||
|
@ -979,10 +978,10 @@ static irqreturn_t flexcan_irq(int irq, void *dev_id)
|
||||||
|
|
||||||
reg_esr = priv->read(®s->esr);
|
reg_esr = priv->read(®s->esr);
|
||||||
|
|
||||||
/* ACK all bus error and state change IRQ sources */
|
/* ACK all bus error, state change and wake IRQ sources */
|
||||||
if (reg_esr & FLEXCAN_ESR_ALL_INT) {
|
if (reg_esr & (FLEXCAN_ESR_ALL_INT | FLEXCAN_ESR_WAK_INT)) {
|
||||||
handled = IRQ_HANDLED;
|
handled = IRQ_HANDLED;
|
||||||
priv->write(reg_esr & FLEXCAN_ESR_ALL_INT, ®s->esr);
|
priv->write(reg_esr & (FLEXCAN_ESR_ALL_INT | FLEXCAN_ESR_WAK_INT), ®s->esr);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* state change interrupt or broken error state quirk fix is enabled */
|
/* state change interrupt or broken error state quirk fix is enabled */
|
||||||
|
|
Loading…
Reference in New Issue