2022-01-05 23:56:28 +03:00
CAN Bus Emulation Support
=========================
2018-01-24 00:04:22 +03:00
The CAN bus emulation provides mechanism to connect multiple
2024-01-03 20:28:17 +03:00
emulated CAN controller chips together by one or multiple CAN buses
(the controller device "canbus" parameter). The individual buses
2018-01-24 00:04:22 +03:00
can be connected to host system CAN API (at this time only Linux
SocketCAN is supported).
2024-01-03 20:28:17 +03:00
The concept of buses is generic and different CAN controllers
2020-09-14 11:13:41 +03:00
can be implemented.
The initial submission implemented SJA1000 controller which
is common and well supported by by drivers for the most operating
systems.
2018-01-24 00:04:22 +03:00
The PCI addon card hardware has been selected as the first CAN
interface to implement because such device can be easily connected
2020-03-10 00:58:18 +03:00
to systems with different CPU architectures (x86, PowerPC, Arm, etc.).
2018-01-24 00:04:22 +03:00
2020-09-14 11:13:41 +03:00
In 2020, CTU CAN FD controller model has been added as part
2020-11-17 22:34:48 +03:00
of the bachelor thesis of Jan Charvat. This controller is complete
2020-09-14 11:13:41 +03:00
open-source/design/hardware solution. The core designer
of the project is Ondrej Ille, the financial support has been
provided by CTU, and more companies including Volkswagen subsidiaries.
2018-01-24 00:04:22 +03:00
The project has been initially started in frame of RTEMS GSoC 2013
slot by Jin Yang under our mentoring The initial idea was to provide generic
CAN subsystem for RTEMS. But lack of common environment for code and RTEMS
testing lead to goal change to provide environment which provides complete
emulated environment for testing and RTEMS GSoC slot has been donated
to work on CAN hardware emulation on QEMU.
2020-11-17 22:34:48 +03:00
Examples how to use CAN emulation for SJA1000 based boards
2022-01-05 23:56:28 +03:00
----------------------------------------------------------
2018-01-24 00:04:22 +03:00
When QEMU with CAN PCI support is compiled then one of the next
CAN boards can be selected
2022-01-05 23:56:28 +03:00
(1) CAN bus Kvaser PCI CAN-S (single SJA1000 channel) board. QEMU startup options::
2018-01-24 00:04:22 +03:00
-object can-bus,id=canbus0
-device kvaser_pci,canbus=canbus0
2022-01-05 23:56:28 +03:00
Add "can-host-socketcan" object to connect device to host system CAN bus::
2018-01-24 00:04:22 +03:00
-object can-host-socketcan,id=canhost0,if=can0,canbus=canbus0
2022-01-05 23:56:28 +03:00
(2) CAN bus PCM-3680I PCI (dual SJA1000 channel) emulation::
2018-01-24 00:04:22 +03:00
-object can-bus,id=canbus0
-device pcm3680_pci,canbus0=canbus0,canbus1=canbus0
2022-01-05 23:56:28 +03:00
Another example::
2018-01-24 00:04:22 +03:00
-object can-bus,id=canbus0
-object can-bus,id=canbus1
-device pcm3680_pci,canbus0=canbus0,canbus1=canbus1
2022-01-05 23:56:28 +03:00
(3) CAN bus MIOe-3680 PCI (dual SJA1000 channel) emulation::
2018-01-24 00:04:22 +03:00
2022-01-05 23:56:28 +03:00
-device mioe3680_pci,canbus0=canbus0
2018-01-24 00:04:22 +03:00
The ''kvaser_pci'' board/device model is compatible with and has been tested with
2022-01-05 23:56:28 +03:00
the ''kvaser_pci'' driver included in mainline Linux kernel.
2018-01-24 00:04:22 +03:00
The tested setup was Linux 4.9 kernel on the host and guest side.
2022-01-05 23:56:28 +03:00
Example for qemu-system-x86_64::
2018-01-24 00:04:22 +03:00
2018-06-13 08:05:19 +03:00
qemu-system-x86_64 -accel kvm -kernel /boot/vmlinuz-4.9.0-4-amd64 \
2018-01-24 00:04:22 +03:00
-initrd ramdisk.cpio \
-virtfs local,path=shareddir,security_model=none,mount_tag=shareddir \
-object can-bus,id=canbus0 \
-object can-host-socketcan,id=canhost0,if=can0,canbus=canbus0 \
-device kvaser_pci,canbus=canbus0 \
-nographic -append "console=ttyS0"
2022-01-05 23:56:28 +03:00
Example for qemu-system-arm::
2018-01-24 00:04:22 +03:00
qemu-system-arm -cpu arm1176 -m 256 -M versatilepb \
-kernel kernel-qemu-arm1176-versatilepb \
-hda rpi-wheezy-overlay \
-append "console=ttyAMA0 root=/dev/sda2 ro init=/sbin/init-overlay" \
-nographic \
-virtfs local,path=shareddir,security_model=none,mount_tag=shareddir \
-object can-bus,id=canbus0 \
-object can-host-socketcan,id=canhost0,if=can0,canbus=canbus0 \
-device kvaser_pci,canbus=canbus0,host=can0 \
The CAN interface of the host system has to be configured for proper
bitrate and set up. Configuration is not propagated from emulated
devices through bus to the physical host device. Example configuration
2022-01-05 23:56:28 +03:00
for 1 Mbit/s::
2018-01-24 00:04:22 +03:00
ip link set can0 type can bitrate 1000000
ip link set can0 up
Virtual (host local only) can interface can be used on the host
2022-01-05 23:56:28 +03:00
side instead of physical interface::
2018-01-24 00:04:22 +03:00
ip link add dev can0 type vcan
The CAN interface on the host side can be used to analyze CAN
2022-01-05 23:56:28 +03:00
traffic with "candump" command which is included in "can-utils"::
2018-01-24 00:04:22 +03:00
candump can0
2020-09-14 11:13:41 +03:00
CTU CAN FD support examples
2022-01-05 23:56:28 +03:00
---------------------------
2020-09-14 11:13:41 +03:00
This open-source core provides CAN FD support. CAN FD drames are
delivered even to the host systems when SocketCAN interface is found
CAN FD capable.
2020-11-17 22:34:48 +03:00
The PCIe board emulation is provided for now (the device identifier is
ctucan_pci). The default build defines two CTU CAN FD cores
2020-09-14 11:13:41 +03:00
on the board.
Example how to connect the canbus0-bus (virtual wire) to the host
Linux system (SocketCAN used) and to both CTU CAN FD cores emulated
on the corresponding PCI card expects that host system CAN bus
2022-01-05 23:56:28 +03:00
is setup according to the previous SJA1000 section::
2020-09-14 11:13:41 +03:00
qemu-system-x86_64 -enable-kvm -kernel /boot/vmlinuz-4.19.52+ \
-initrd ramdisk.cpio \
-virtfs local,path=shareddir,security_model=none,mount_tag=shareddir \
-vga cirrus \
-append "console=ttyS0" \
-object can-bus,id=canbus0-bus \
-object can-host-socketcan,if=can0,canbus=canbus0-bus,id=canbus0-socketcan \
-device ctucan_pci,canbus0=canbus0-bus,canbus1=canbus0-bus \
-nographic
2022-01-05 23:56:28 +03:00
Setup of CTU CAN FD controller in a guest Linux system::
2020-09-14 11:13:41 +03:00
insmod ctucanfd.ko || modprobe ctucanfd
insmod ctucanfd_pci.ko || modprobe ctucanfd_pci
for ifc in /sys/class/net/can* ; do
if [ -e $ifc/device/vendor ] ; then
if ! grep -q 0x1760 $ifc/device/vendor ; then
continue;
fi
else
continue;
fi
if [ -e $ifc/device/device ] ; then
if ! grep -q 0xff00 $ifc/device/device ; then
continue;
fi
else
continue;
fi
ifc=$(basename $ifc)
/bin/ip link set $ifc type can bitrate 1000000 dbitrate 10000000 fd on
/bin/ip link set $ifc up
done
2022-01-05 23:56:28 +03:00
The test can run for example::
2020-09-14 11:13:41 +03:00
candump can1
2022-01-05 23:56:28 +03:00
in the guest system and next commands in the host system for basic CAN::
2020-09-14 11:13:41 +03:00
cangen can0
2022-01-05 23:56:28 +03:00
for CAN FD without bitrate switch::
2020-09-14 11:13:41 +03:00
cangen can0 -f
2022-01-05 23:56:28 +03:00
and with bitrate switch::
2020-09-14 11:13:41 +03:00
cangen can0 -b
2022-11-10 22:08:25 +03:00
The test can also be run the other way around, generating messages in the
guest system and capturing them in the host system. Other combinations are
also possible.
2020-09-14 11:13:41 +03:00
2018-01-24 00:04:22 +03:00
Links to other resources
2022-01-05 23:56:28 +03:00
------------------------
(1) `CAN related projects at Czech Technical University, Faculty of Electrical Engineering <http://canbus.pages.fel.cvut.cz> `_
(2) `Repository with development can-pci branch at Czech Technical University <https://gitlab.fel.cvut.cz/canbus/qemu-canbus> `_
(3) `RTEMS page describing project <https://devel.rtems.org/wiki/Developer/Simulators/QEMU/CANEmulation> `_
(4) `RTLWS 2015 article about the project and its use with CANopen emulation <http://cmp.felk.cvut.cz/~pisa/can/doc/rtlws-17-pisa-qemu-can.pdf> `_
(5) `GNU/Linux, CAN and CANopen in Real-time Control Applications Slides from LinuxDays 2017 (include updated RTLWS 2015 content) <https://www.linuxdays.cz/2017/video/Pavel_Pisa-CAN_canopen.pdf> `_
(6) `Linux SocketCAN utilities <https://github.com/linux-can/can-utils> `_
(7) `CTU CAN FD project including core VHDL design, Linux driver, test utilities etc. <https://gitlab.fel.cvut.cz/canbus/ctucanfd_ip_core> `_
2022-04-02 23:45:23 +03:00
(8) `CTU CAN FD Core Datasheet Documentation <http://canbus.pages.fel.cvut.cz/ctucanfd_ip_core/doc/Datasheet.pdf> `_
(9) `CTU CAN FD Core System Architecture Documentation <http://canbus.pages.fel.cvut.cz/ctucanfd_ip_core/doc/System_Architecture.pdf> `_
(10) `CTU CAN FD Driver Documentation <https://canbus.pages.fel.cvut.cz/ctucanfd_ip_core/doc/linux_driver/build/ctucanfd-driver.html> `_
2022-01-05 23:56:28 +03:00
(11) `Integration with PCIe interfacing for Intel/Altera Cyclone IV based board <https://gitlab.fel.cvut.cz/canbus/pcie-ctu_can_fd> `_