SocketCAN Installation on Raspberry PI OS

git clone https://github.com/InfluxTechnology/rexgen-socketcan.git

  1. Install raspberrypi-kernal-headers

sudo apt-get install raspberrypi-kernel-headers
  1. Install can-utils

This will install the necessary tools to acquire CAN data using SocketCAN

sudo apt-get install can-utils
  1. Open the rexgen-socketcan folder

  2. Load the can-dev module

sudo modprobe can-dev
  1. Run the do_make.sh script

sudo ./domake.sh
  1. Ignore any Warnings

  2. Plugin the ReXgen Device

  3. Reboot the device

Using Socket CAN

  1. Before you can send and receive data, you need to configure the interface. To do this, you can use the 'ip' tool. For example, if you want to set the bitrate of 500Kbit (500000 bit) to the can0 interface, you can do this with

    "sudo ip link set can0 type can bitrate 500000"

    If you need to set CAN FD with a bitrate of 500Kbit and data bitrate of 8Mbit

    "sudo ip link set can0 type can bitrate 500000 dbitrate 8000000 fd on"

    We support loopback mode and listen-only mode. Typical socket can syntax is

    "sudo ip link set can0 type can bitrate 500000 dbitrate 8000000 fd on loopback on|off"

    "sudo ip link set can0 type can bitrate 500000 dbitrate 8000000 fd on listen-only on|off"

    We also support CANFD non-ISO mode via fd-non-iso on|off

  2. Now the bitrate is set, and you can start the interface by typing

    "sudo ip link set can0 up"

  3. After this, you can send and receive data on CAN0. At the beginning, you may want to check some small communications. To do this, you could use the tools from "can-utils". For example, you could try to send data with

    "cansend can0 123#112233" - Simple CAN message

    "cansend can0 00000123#112233" - CAN message with ID Extended (IDE)

    "cansend can0 123##0112233" - Simple CANFD message

    "cansend can0 123##1112233" - CANFD message (EDL) with BRS flag

    "cansend can0 00000123##1112233" - CANFD message (EDL) with BRS flag and IDE

    and receive it with

    "candump can0"

    or

    "candump can0 -x" for extra details

    As a prerequisite for this is a connected and properly configured bus with at least two communication partners

Last updated