Skip to content

Commit

Permalink
docs: networking: device drivers: can: add flexcan
Browse files Browse the repository at this point in the history
Add initial documentation for Flexcan driver.

Link: https://lore.kernel.org/all/20220107193105.1699523-8-mkl@pengutronix.de
Signed-off-by: Dario Binacchi <dario.binacchi@amarulasolutions.com>
Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
  • Loading branch information
passgat authored and marckleinebudde committed Jan 8, 2022
1 parent 32db166 commit bc3897f
Show file tree
Hide file tree
Showing 2 changed files with 56 additions and 0 deletions.
54 changes: 54 additions & 0 deletions Documentation/networking/device_drivers/can/freescale/flexcan.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
.. SPDX-License-Identifier: GPL-2.0+
=============================
Flexcan CAN Controller driver
=============================

Authors: Marc Kleine-Budde <mkl@pengutronix.de>,
Dario Binacchi <dario.binacchi@amarula.solutions.com>

On/off RTR frames reception
===========================

For most flexcan IP cores the driver supports 2 RX modes:

- FIFO
- mailbox

The older flexcan cores (integrated into the i.MX25, i.MX28, i.MX35
and i.MX53 SOCs) only receive RTR frames if the controller is
configured for RX-FIFO mode.

The RX FIFO mode uses a hardware FIFO with a depth of 6 CAN frames,
while the mailbox mode uses a software FIFO with a depth of up to 62
CAN frames. With the help of the bigger buffer, the mailbox mode
performs better under high system load situations.

As reception of RTR frames is part of the CAN standard, all flexcan
cores come up in a mode where RTR reception is possible.

With the "rx-rtr" private flag the ability to receive RTR frames can
be waived at the expense of losing the ability to receive RTR
messages. This trade off is beneficial in certain use cases.

"rx-rtr" on
Receive RTR frames. (default)

The CAN controller can and will receive RTR frames.

On some IP cores the controller cannot receive RTR frames in the
more performant "RX mailbox" mode and will use "RX FIFO" mode
instead.

"rx-rtr" off

Waive ability to receive RTR frames. (not supported on all IP cores)

This mode activates the "RX mailbox mode" for better performance, on
some IP cores RTR frames cannot be received anymore.

The setting can only be changed if the interface is down::

ip link set dev can0 down
ethtool --set-priv-flags can0 rx-rtr {off|on}
ip link set dev can0 up
2 changes: 2 additions & 0 deletions Documentation/networking/device_drivers/can/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@ Contents:
.. toctree::
:maxdepth: 2

freescale/flexcan

.. only:: subproject and html

Indices
Expand Down

0 comments on commit bc3897f

Please sign in to comment.