This software implements an USB to CAN bridge compatible with Linux can-utils and slcan driver.
This software application is designed to run on flipper zero device and needs SERMA CAN FD board to be plugged in GPIOs ports available here.
When entering the application (by selecting can-fd-hs) from main menu or by selecting Apps/USB-CAN, a list appears with 3 choices which represent the 3 modes of the application detailled in next sections :
- USB-CAN Bridge : This is the main mode which is used as a bridge between can-utils and a CAN device under test.
- TEST USB LOOPBACK : This mode is used to test connectivity between host computer and flipper zero.
- CAN TEST : This mode is used to test CAN connectivity. This send "CANALIVE" through CAN.
This mode have to be entered before issuing any configuration command. Then you can :
- Create a CAN network interface through USB Virtual com port (VCP) :
sudo slcand -s<X> <options> ttyACM<Y> can<Z>
. - enable your created network interface
sudo ifconfig can<X> up
. - operate normally your can interface by using
cansend can<X> <iii>#<dddddddd>
andcandump can<X>
commands.
Please refer to can-utils for more details.
If issues are encountered, you can get more informations by connecting directly to vcp with tool like putty :
- serial mode
- 8 data bits
- no parity
- no hardware control flow
You can see the following screenshot for more informations:
This mode can also be used to configure connection in flexible datarate ("S9" command).
NB1 : beware of command line termination. It must be a carriage return '\r'. For more convenience newline '\n' characters located after carriage returns are ignored.
NB2 : for compatibility reason (with can-utils) newline character is not appended after CAN RX frames.As a consequence display of these frames is impacted. To avoid this send "d" on VCP to enter in debug mode.
NB3 : beware of usb cdc buffer length. Max size is 64. So command number that can be sent in one frame is limited.
This mode is used to test VCP (USB cdc) connectivity. To use this mode, you have to :
- connect to the VCP with any VCP tool like putty :
- serial mode
- 8 data bits
- no parity
- no hardware control flow
- Once the connection is established message USB loopback is displayed, the user can test connection by sending characters on serial line and checking the content sent is sent back on serial line by the flipper device.
This mode is used to test CAN connection (to verify wiring between CAN device under test and flipper zero board).
No user action is required before using this mode (except the obvious wiring step).
The frame sent every 200 ms shall by the device shall be the following :
- 007E5TCA:43414E4C49564500 : IIIIIIII:DDDDDDDDDDDDDDDD with
- <III..> the extended identifier (007E57CA = "TESTCA" in hexspeak)
- <DDD..> the data (43414E4C49564500 = "CANLIVE" in ascii).
note : You can first check Tx LED blinks and transmitted byte counter (on flipper screen) increment by 8 every 200ms to diagnose problems.
Documentation can be found here.
To re-generate documentation you have to install doxygen
before running Documentation/generate_doc.sh [--open]
(--open is used to open documentation after the generation).
This application is based on:
- XTREME firmware USB-UART bridge application : It has been modified to send data on CAN (via SPI) and not on UART.
- Longan Labs Longan_CANFD library : this is the driver for the MCP 2518 CAN transceiver.
More information on architecture is given in docs (cf. previous section).
Application is built as an external app using standard fbt commands. Please refer to flipper documentation for more information.
Applications has been tested with a MCP2515 evaluation board. As a consequence, only the following datarates are tested :
- 125 Kbaud
- 250 Kbaud
- 500 Kbaud
- 1 MBaud
Note: the flexible datarate is not tested yet.
Multiple exit and enters in application and its submode produce instable behaviour.