diff options
author | Marc Kleine-Budde <mkl@pengutronix.de> | 2013-10-04 10:52:36 +0200 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2013-11-13 12:05:31 +0900 |
commit | d60241f65bdc363f1be2b099bd98ff13a96c1f0d (patch) | |
tree | 2f98989cd9f827611c644ca236fa2884fb5685fd /virt | |
parent | e350ff50bcd46d650d56015a1416c622d057ec90 (diff) | |
download | linux-3.10-d60241f65bdc363f1be2b099bd98ff13a96c1f0d.tar.gz linux-3.10-d60241f65bdc363f1be2b099bd98ff13a96c1f0d.tar.bz2 linux-3.10-d60241f65bdc363f1be2b099bd98ff13a96c1f0d.zip |
can: flexcan: flexcan_chip_start: fix regression, mark one MB for TX and abort pending TX
commit d5a7b406c529e4595ce03dc8f6dcf7fa36f106fa upstream.
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: Lothar Waßmann <LW@KARO-electronics.de>
Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'virt')
0 files changed, 0 insertions, 0 deletions