can: flexcan: flexcan_chip_start: fix regression, mark one MB for TX and abort pending TX
authorMarc Kleine-Budde <mkl@pengutronix.de>
Fri, 4 Oct 2013 08:52:36 +0000 (10:52 +0200)
committerMarc Kleine-Budde <mkl@pengutronix.de>
Wed, 9 Oct 2013 21:01:35 +0000 (23:01 +0200)
commitd5a7b406c529e4595ce03dc8f6dcf7fa36f106fa
treeb53ac411845daaedd3e2d287974301eea1b36a01
parent87b0a0b5c46aea63cdc5c5d788fe2c91406e3161
can: flexcan: flexcan_chip_start: fix regression, mark one MB for TX and abort pending TX

In patch

    0d1862e can: flexcan: fix flexcan_chip_start() on imx6

the loop in flexcan_chip_start() that iterates over all mailboxes after the
soft reset of the CAN core was removed. This loop put all mailboxes (even the
ones marked as reserved 1...7) into EMPTY/INACTIVE mode. On mailboxes 8...63,
this aborts any pending TX messages.

After a cold boot there is random garbage in the mailboxes, which leads to
spontaneous transmit of CAN frames during first activation. Further if the
interface was disabled with a pending message (usually due to an error
condition on the CAN bus), this message is retransmitted after enabling the
interface again.

This patch fixes the regression by:
1) Limiting the maximum number of used mailboxes to 8, 0...7 are used by the RX
FIFO, 8 is used by TX.
2) Marking the TX mailbox as EMPTY/INACTIVE, so that any pending TX of that
mailbox is aborted.

Cc: linux-stable <stable@vger.kernel.org>
Cc: Lothar Waßmann <LW@KARO-electronics.de>
Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
drivers/net/can/flexcan.c