1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 09:52:45 +01:00
RIOT/tests/conn_can
2022-02-28 21:59:57 +01:00
..
main.c tests/conn_can: Add can tranceiver 2020-05-11 14:10:42 +02:00
Makefile tests: add building BOARD defaults 2022-02-28 21:59:57 +01:00
Makefile.ci boards: introduce atmega328p-xplained-mini 2021-03-27 14:10:19 -03:00
README.md tests/conn_can: Add to README 2020-08-27 16:35:40 +02:00

tests/conn_can

Demo application for the CAN stack with conn_can interface.

Native prerequisites

For using the can stack on top of socketCAN, available for linux, you need:

  • socketCAN (part of kernel starting from 2.6.25)
  • install the 32bit version of libsocketcan:

if you're on a 64bit system:

sudo dpkg --add-architecture i386
sudo apt-get update
sudo apt-get install libsocketcan-dev:i386

On 32 bit you can just do the following:

sudo apt-get install libsocketcan-dev

Alternatively, you can compile from source:

wget http://www.pengutronix.de/software/libsocketcan/download/libsocketcan-0.0.11.tar.bz2

$ tar xvjf libsocketcan-0.0.11.tar.bz2

$ rm -rf libsocketcan-0.0.11.tar.bz2

$ cd libsocketcan-0.0.11

$ ./configure

compile in 32bits

./configure --build=i686-pc-linux-gnu "CFLAGS=-m32" "CXXFLAG

$ make

$ sudo make install


sudo ldconfig
/usr/local/lib

The default native configuration defines two virtual can ifaces to be used. Before running this test on native, you should create those:

sudo modprobe vcan
sudo ip link add dev vcan0 type vcan
sudo ip link add dev vcan1 type vcan
sudo ip link set vcan0 up
sudo ip link set vcan1 up

Usage

Adapt pin configuration in Makefile to match the used CAN transceiver (e.g. TJA1042_STB_PIN)

Build, flash and start the application:

export BOARD=your_board
make
make flash
make term

To initialize a CAN transceiver device (trx_id = 0)

init 0

To set a CAN transceiver device's (trx_id = 0) mode to TRX_NORMAL_MODE

set_mode 0 0

The CAN interfaces are registered at startup to the dll. The list of registered interfaces and their RIOT names can be retrieved with:

test_can list

To send a raw CAN frame, id 0x100 with 2 bytes of data 01 02 on interface 0:

test_can send 0 100 01 02

To send a raw CAN remote request frame, id 0x100 on interface 0 and datalenght 7:

test_can sendrtr 0 100 7

A remote request frame has a NULL payload but can have a specific data length code (DLC). Valid DLC val: 0..8

Two threads are launched to enable receiving frames. To receive raw CAN frames, ids 0x100 and 0x500 with thread 0 on interface 1, with 10s timeout:

test_can recv 1 0 10000000 100 500

A connection can be closed with its thread id, for instance:

test_can close 0

To send an ISO-TP datagram, first bind a connection with one of the threads, source id 700, dest id 708, thread 1 and interface 0:

test_can bind_isotp 0 1 700 708

Then send the data 01 02 03 04 05 0a 0b 0c:

test_can send_isotp 1 01 02 03 04 05 0a 0b 0c

To receive from an ISO-TP channel, it must be bound, then with the previous channel, and 10s timeout:

test_can recv_isotp 1 10000000

An ISO-TP channel can be closed with:

test_can close_isotp 1

You can also set a bitrate (this won't work on native with vcan, only with real interfaces, but then root access are needed), for instance 250000 bit/s with sampling point 87.5%:

test_can set_bitrate 250000 875

Linux CAN basic commands

Once the interfaces are set up, can-utils commands provide a way to send and receive raw CAN frames and ISO-TP datagrams.

For ISO-TP, an experimental module for linux can be found here. It needs to be loaded before trying to use ISO-TP protocol.

Here are some basics examples.

Send a raw CAN frame, id 0x100, data 00 11 22:

cansend vcan0 100#001122

Dump the traffic on a CAN interface:

candump vcan0

Send an ISO-TP datagram, source id 700, dest id 708, data 00 11 22 33 aa bb cc dd:

echo 00 11 22 33 aa bb cc dd | isotpsend -s 700 -d 708 vcan0

Receive ISO-TP datagram:

isotprecv -s 708 -d 700 vcan0

Please read commands help for more details on usage.