mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-15 19:52:45 +01:00
a7880ab98d
This test app bypasses candll and uses the candev abstraction directly. This has the limitation that you can only use one can driver and one can device, which is in most use cases sufficient.
110 lines
2.4 KiB
Markdown
110 lines
2.4 KiB
Markdown
# Candev abstraction test
|
|
|
|
## About
|
|
|
|
This application is a test for using the candev abstraction directly.
|
|
Use this if you want to use a single CAN driver and thus don't need the CAN-DLL layer.
|
|
|
|
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.10.tar.bz2
|
|
$ sudo tar xvjf libsocketcan-0.0.10.tar.bz2
|
|
|
|
$ sudo rm -rf libsocketcan-0.0.10.tar.bz2
|
|
|
|
$ sudo cd libsocketcan-0.0.10
|
|
|
|
$ sudo ./configure
|
|
|
|
compile in 32bits
|
|
|
|
./configure --build=i686-pc-linux-gnu "CFLAGS=-m32" "CXXFLAG
|
|
|
|
$ sudo 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
|
|
|
|
### Sending
|
|
|
|
Messages can be sent over the CAN-bus through the `send` command. Optionally, up to 8 bytes can be passed as arguments (in decimal form). If no arguments are passed it will default to sending AB CD EF (hex).
|
|
|
|
```
|
|
send <bytes>
|
|
```
|
|
|
|
When running the app native on linux, the sent bytes can be seen by scanning the CANbus with candump:
|
|
|
|
```
|
|
$ candump vcan0
|
|
```
|
|
|
|
### Receiving
|
|
|
|
The test-app is always listening for incoming CAN messages. They will be stored asynchronously in a buffer and can be requested by means of the `receive` command. Optionally, an argument n can be passed to receive n messages in a row.
|
|
|
|
```
|
|
receive <n>
|
|
```
|
|
|
|
If more messages are requested than are available in the buffer, the receive function will block until new data is available.
|
|
|
|
When running the app native on linux, data can be sent with `cansend`:
|
|
|
|
```
|
|
$ cansend <interface> <can_id>:<hexbytes>
|
|
```
|
|
|
|
e.g.:
|
|
|
|
```
|
|
$ cansend vcan0 001:1234ABCD
|
|
```
|
|
|
|
An alternative is to use `cangen` to generate a number of random can messages:
|
|
|
|
```
|
|
$ cangen <interface> -v -n <n>
|
|
```
|
|
|
|
e.g.:
|
|
|
|
```
|
|
$ cangen vcan0 -v -n 5
|
|
```
|
|
|
|
will send 5 can messages to vcan0 with verbose output.
|