CAN Bus Data Logging¶
OVMS can be used as CAN bus datalogging tool.
Note: ‘Edge’ firmware is currently required for full CAN bus datalogging functions.
3.2.002-191-g8d532fb/ota_0/edge (build idf v3.1-dev-4770-ge97f72e Aug 26 2019 00:00:50
Edge firmware can be selected via the web interface ‘config > firmware’, enter
edge in firmware tag. To load edge firmware select ‘flash from web > Flash now’.
OVMS hardware V3 supports up to three CAN bus connections. The connections to OVMS are as follows:
DB9-F Signal ----- ------ 2 CAN1-L 7 CAN1-H 4 CAN2-L 5 CAN2-H 6 CAN3-L 8 CAN3-H
Note: the board schematics refer to CAN0,1,2. These correspond to CAN1,2,3 here in the documentation and source code. The first is handled by ESP32 i/o lines directly, and CAN2/3 are handled by MCP2515 ICs via SPI from the ESP.
Vehicle CAN bus(s) are usually accesable via the vehicle’s OBD2 port. Most modern cars have multiple CAN busses. The OBD2 ‘standard’ CAN will be available on OBD2 pin 6: CAN-H and pin 14: CAN-L. However, modern vehicles (especially EV’s) often have other CAN buses available on non-standard OBD2 pins.
A voltmeter (ideally oscilloscope) can be used to determine which OBD2 pins contain CAN data:
- Can high pins should normally be between 2.5 and 3.5 volts (to ground) - maybe 2.7 to 3.3 volts if there is traffic.
- Can low pins should normally be between 1.5 and 2.5 volts (to ground) - maybe 1.7 to 2.3 volts if there is traffic.
Pre-fabricated OBD2 > DB9-F for several specific vehicles can be purchased via OpenVehicles.
Enable OVMS CAN bus¶
Once physical connections has been made and OVMS is up and running connect to OVMS shell via web browser / SSH or serial.
If a specific vehicle module is loaded the CAN bus will already be enabled in OVMS. To check which CAN buses are enabled use:
OVMS# can list
If no vehicle module is selected the CAN bus must be started e.g
OVMS# can can1 start listen 500000
This will enable
listen mode (read only) at 50k baud,
active can be used instead of listen to enable read-write mode. To stop a
OVMS# can can1 stop
OVMS supports the following CAN bauds rates:
100000, 125000, 250000, 500000, 1000000.
Logging to SD card¶
It is possible to view CAN data directly in OVMS monitor shell, however Since modern cars have very busy CAN buses there is often too much data which swamps the monitor. Logging to SD card is the best option.
If using a good quality SD card a modern OVMS V3 module, increase the SD card speed for best performance with:
config set sdcard maxfreq.khz 20000
Start logging all CAN messages using CRTD log file format with:
ovms# can log start vfs crtd /sd/can.crtd
or log specific CAN packets by applying a filter e.g 0x55b the Nissan LEAF SoC CAN message
ovms# can log start vfs crtd /sd/can.crtd 55b
Other CAN log file formats are supported e.g
crtd, gvret-a, gvret-b, lawricel, pcap, raw.
Check CAN logging satus with:
ovms# can log status
To Stop CAN logging:
ovms# can log stop
Note: the can logging must be stopped before file can be viewed
To View the CAN log:
ovms# vfs head /sd/can.crtd
cat commands can also be used. However, be careful the log file can quickly become very large,
cat may overwhelm the shell.
The log file can also be viewed in a browser with
The logfiles can then be imported into a tool like SavvyCan for analysis.
CAN data can be streamed directly to SavvyCan (or other compatible application) using the OVMS tcpserver CAN logging feature over a local network. Start tcpserver CAN logging with:
OVMS# can log start tcpserver discard gvret-b :23
This will start a tcpserver on port 23 (as required by SavvyCan) using the GVRET format supported by SavvyCAN.
Once OVMS CAN logging tcpserver is running open up SavvyCan and select:
Connection > Add New Device Connection > Network Connection
then enter the OVMS WiFi local network IP address (no port number required). CAN packets should now appear streaming into SavvyCan.
Note: CAN tcpserver network streaming is a beta feture currently in edge firmware and may be buggy