Skip to content

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.

License

Notifications You must be signed in to change notification settings

serma-safety-security/Flipper-Zero-CAN-FD-HS-SW

Repository files navigation

Flipper Zero CAN FD HS SW

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.
Flipper zero CAN FD

Usage

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.

USB-CAN Bridge

This mode have to be entered before issuing any configuration command. Then you can :

  1. Create a CAN network interface through USB Virtual com port (VCP) :sudo slcand -s<X> <options> ttyACM<Y> can<Z>.
  2. enable your created network interface sudo ifconfig can<X> up.
  3. operate normally your can interface by using cansend can<X> <iii>#<dddddddd> and candump 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:

debug mode

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.

TEST USB LOOPBACK

This mode is used to test VCP (USB cdc) connectivity. To use this mode, you have to :

  1. connect to the VCP with any VCP tool like putty :
    • serial mode
    • 8 data bits
    • no parity
    • no hardware control flow
  2. 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.

USB loopback

TEST CAN

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).

test can

note : You can first check Tx LED blinks and transmitted byte counter (on flipper screen) increment by 8 every 200ms to diagnose problems.

Development

documentation

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).

architecture overview

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.

Test status

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

Flipper zero CAN FD test setup

Note: the flexible datarate is not tested yet.

Known bugs

Multiple exit and enters in application and its submode produce instable behaviour.

About

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.

Resources

License

Stars

Watchers

Forks

Packages

No packages published