Programs and scripts

init-can.sh

This program is used to set up your CAN bus device.

Here is the online help from the program:

$ ./init-can.sh -h
init-can.sh - initialize CAN interfaces

This script initializes one or several CAN interfaces.

Usage:
  init-can.sh [OPTIONS]

Known options:
  -h : this help
  -d --driver DRIVER : specify the CAN driver to use (mandatory)
    Known values for DRIVER are:
    - vcan     : virtual CAN interface from standard linux kernel
    - none     : do not load a driver, just try to initialize CAN ports
                 named 'can<portnumber>'
    - peak     : peak_pciefd driver from standard linux kernel
                 for the PEAK PCAN-PCI Express FD card
    - peak-usb : peak_usb driver from standard linux kernel
                 for the PEAK USB adapters
    - pcan     : proprietary driver from PEAK Systems built from source
    You can also provide an arbitary name for DRIVER, the script
    will then try to load this kernel module.
    The script assumes that physical CAN interfaces are always
    named 'can0', 'can1', 'can2'... and that virtual CAN interfaces
    are named 'vcan0', 'vcan1', 'vcan2'...
  -p --ports STARTPORT [ENDPORT]: define a port range or a single port
    The CAN devicenames used are can<PORT> or vcan<PORT>.
  -b --bitrate BITRATE: define a bitrate, default is 1000000
  -n --dry-run : show what the script would do

This script requires that you have 'sudo' permissions

The script can initialize physical CAN interfaces and virtual CAN interfaces.

It loads the kernel module, sets the bitrate and brings up the interface. An interface is adressed just with a port number, starting with 0.

Examples:

Initialize virtual CAN interfaces port 0 to 3:

init-can.sh -d vcan -p 0 3

Initialize physical CAN interfaces for PEAK-PCI port 0 to 3:

init-can.sh -d peak -p 0 3

Set bitrate for port 2 to 500KBit:

init-can.sh -d peak -p 2 -b 500000

Initialize physical CAN interfaces for PEAK-USB port 0, 1MBit:

init-can.sh -d peak-usb -p 0 3 -b 1000000

show-can-devices.sh

This script shows all CAN devices in your system.

Here is the online help from the program:

$ ./show-can-devices.sh -h
show-can-devices.sh - show CAN bus devices

This lists CAN Bus devices if they exist.

Usage:
  show-can-devices.sh [OPTIONS]

Known options:
  -h : this help

You usually run the program without any arguments or options, here is an example:

$ ./show-can-devices.sh
8: can0: <NOARP,UP,LOWER_UP,ECHO> mtu 16 qdisc pfifo_fast state UP mode DEFAULT group default qlen 1000
    link/can
9: can1: <NOARP,UP,LOWER_UP,ECHO> mtu 16 qdisc pfifo_fast state UP mode DEFAULT group default qlen 1000
    link/can

can-state.sh

This script shows detailed information on a CAN interface.

Here is the online help from the program:

$ ./can-state.sh -h
can-state.sh - Show the state of CAN devices

Usage:
  can-state.sh [OPTIONS]

Known options:
  -h : this help
  -p --ports STARTPORT [ENDPORT]: define a port range or a single port
    The CAN devicenames used are for physical CAN devices and
    vcan<PORT> for virtual CAN devices.
  --virtual : Use device name for virtual CAN device.

Here is an example:

$ ./can-state.sh -p 0
8: can0: <NOARP,UP,LOWER_UP,ECHO> mtu 16 qdisc pfifo_fast state UP mode DEFAULT group default qlen 1000
    link/can  promiscuity 0 allmulti 0 minmtu 0 maxmtu 0
    can state ERROR-ACTIVE (berr-counter tx 0 rx 0) restart-ms 0
        bitrate 1000000 sample-point 0.750
        tq 12 prop-seg 29 phase-seg1 30 phase-seg2 20 sjw 10 brp 1
        peak_canfd: tseg1 1..256 tseg2 1..128 sjw 1..128 brp 1..1024 brp_inc 1
        peak_canfd: dtseg1 1..32 dtseg2 1..16 dsjw 1..16 dbrp 1..1024 dbrp_inc 1
        clock 80000000
        re-started bus-errors arbit-lost error-warn error-pass bus-off
        0          0          0          0          0          0         numtxqueues 1 numrxqueues 1 gso_max_size 65536 gso_max_segs 65535 tso_max_size 65536 tso_max_segs 65535 gro_max_size 65536 gso_ipv4_max_size 65536 gro_ipv4_max_size 65536 parentbus pci parentdev 0000:05:00.0
    RX:  bytes packets errors dropped  missed   mcast
             4       1      0       0       0       0
    TX:  bytes packets errors dropped carrier collsns
          4016    1003      0       0       0       0

sotest

Hint

If you just want to read or dump CAN data do also have a look at candump, part of the “can-utils” package

This tests the socan library.

Here is the online help from the program:

$ ./sotest -h
 **** sotest 1.0 ****
the socan test program
usage:
sotest {options}
options:
 **************** Configuration*****************
 --interface,-i INTERFACE
        Use INTERFACE for CAN communication, this option
        can be given more than once to use more than one
        interface.
 --realtime READER-PRIORITY WRITER-PRIORITY
        Use given realtime priorities for reader and writer
        thread.
 --leave [SECONDS]
        for all functions that define CAN-objects, hold the
        program just before close() is performed. All CAN
        objects remain defined. End the program with CRTL-C in
        this case
 --trace,-t LEVEL
        set trace level, LEVEL is an integer 0..2 (default 0)
 --errprintlevel,-E LEVEL
        set errprint level, LEVEL is an integer 0..3 (default 1)
 *************** command options ***************
 --loop {no of loops}
        run read, write, readnow or readmany in loop-mode
 --loopdelay {delay}
        delay each loop by the given number of seconds.
        seconds may be a floating point number.
 --sleep {seconds}
        sleep a number of seconds before starting the test.
        seconds may be a floating point number.
 --quiet,-q {level}
        Run read, write, readnow or readmany in quiet-mode
        level may be 1 .. 5, meaning that each 10**(level-1)
        events print a single character on the screen.
        Level 0 means no printing at all.
 --timestamp
        Print a the timestamp for each sent or received
        CAN object. --stats
        run read, readnow or readmany in statistic mode.
        Print number of transmits and errors.
 --maxlossrate [number]
        print a warning when the ratio of lost CAN objects for
        read functions is bigger than [number].
 --check
        check sequence in --read, (must be used together with
        --write in another sotest-task
 --size,-s [bytes]
        use [bytes] bytes to transfer and receive data
 --count [number]
        use [number] as initial number to write with -w
 --consistence
        send alternating 8 bytes of 0xFF or 0x00 to test data
        consistence
 --remote
        do remote-read or remote-write, implemented for
        --write and --read
 --ignore_old
        ignore the SOCAN_OLD-flag

 ***************data transmission commands****************
 --rwtest [object1] [port1] [object2] [port2] [write-timeout] [read-timeout]
        make a write-object (object1,port1) and a read-object
        (object2,port2) with a timeout set for the 2nd object
        then write 8 bytes (values 1 to 8) and read the 2nd
        object (read immediately) and return the results
 --write,-w [object] [port] [timeout]
        write data (a running counter)
 --writelater [object] [port] [timeout]
        similar to write, but writelater returns immediately,
        without waiting for the actual access of the CAN-bus.
        Note: writelater returns only errors that are valid for
              the PREVIOUS writelater !!!
 --writelater-w [object] [port] [timeout]
        the same as --writelater but do silently retry to write
        when the driver returns a SOCAN_WAIT status.
 --writeinhibit [object] [port] [timeout] [inhibit-time]
        similar to writelater, but the CAN-object gets a timestamp
        when it is transmitted. Inhibit-time is the minumum
        time that has to pass before a new object is sent. This
        concerns only writeinhibit combined with the loop-command.
        In this case only about every [inhibit-time]
        microseconds new data will be sent (note that the unit
        for this parameter is microseconds, not milliseconds
 --writertr [object] [port] [timeout]
        Just write an RTR frame on a CAN object.
 --read,-r [object] [port] [timeout]
        read data from an object (blocking).
 --readnow [object] [port] [timeout]
        read data from an object (immediately).
 --queue-read [port] [timeout] [object] {[object]}
        read more than one object via the signal-function in
        conjunction with the new queue-read operation
        together with --remote, all objects will be remote-read
        objects

 ******************** miscellaneous tests ****************
 --bitrate [port]
        get bitrate of a port

Note that you have to specify each can device you intend to use with option “-i”. All devices get a port number in the order they are given. See also the “rwtest” example.

Examples

All examples presume that sotest is in your file search path (PATH).

RW-Test: Test writing COB 0 on CAN port 0 and receiving it on CAN port 1 with a timeout of 1000ms each:

$ sotest -i can0 -i can1 --rwtest 0 0 0 1 1000 1000
opening driver :
8 bytes will be written, content of these 8 bytes:
1 2 3 4 5 6 7 8
set write-mode for object 0, port 0 ...(timeout 1000)
done
set read-mode for object 0, port 1 ...(timeout 1000)
done
now writing the data...done
now reading the data...done
message-content:
       0:  1  2  3  4  5  6  7  8                           "        "
closing driver...

Write a single CAN object with COB 123 on port 0 and timeout 1000ms:

$ sotest -i can0 -w 123 0 1000
opening driver :
defining write-object...
done
writing 0, 4 bytes on 123

closing driver...

Do the same, but write 1000 CAN objects very fast, print a single character on the console every 100 CAN frames:

$ sotest -i can0 -w 123 0 1000 -q 3 --loop 1000
opening driver :
defining write-object...
done
one 'O' are 100 loops!
OOOOOOOOOO

closing driver...

Read and receive a single CAN object with COB 123 on port 0 and timeout 10s. We had another instance of sotest running that did send the CAN object:

$ sotest -i can0 -r 123 0 10000
opening driver :
defining read-object...
done
received data:
       0:  0  0  0  0                                       "    "
closing driver...

Read any of the CAN objects 121, 122 or 123, stop the program after 1000 CAN frames were received. We had another instance of sotest running that did send the three CAN objects:

$ sotest -i can0 --queue-read 0 1000 121 122 123 --loop 1000
opening driver :
defining read-objects...
received on 121: data:
       0:  0  0  0  0                                       "    "
received on 122: data:
       0:  0  0  0  0                                       "    "
received on 123: data:
       0:  0  0  0  0                                       "    "

scitest

This tests the sci library. This program has many options in common with sotest.

Here is the online help from the program:

$ ./scitest -h
 **** scitest 1.0 ****
the sci test program
usage:
scitest {options}
options:
 **************** Configuration*****************
 --interface,-i INTERFACE
        Use INTERFACE for CAN communication, this option
        can be given more than once to use more than one
        interface.
 --realtime READER-PRIORITY WRITER-PRIORITY
        Use given realtime priorities for reader and writer
        thread.
 --leave
        for all functions that define CAN-objects, hold the
        program just before close() is performed. All CAN
        objects remain defined. End the program with CRTL-C in
        this case
 --trace,-t LEVEL
        set trace level, LEVEL is an integer 0..2 (default 0)
 --errprintlevel,-E LEVEL
        set errprint level, LEVEL is an integer 0..3 (default 1)
 *************** command options ***************
 --loop {no of loops}
        run read, write, readnow or readmany in loop-mode
 --sleep {seconds}
        sleep a number of seconds before starting the test.
        seconds may be a floating point number.
 --quiet,-q {level}
        run read, write, readnow or readmany in quiet-mode
        level may be 1 .. 5, meaning that each 10**(level-1)
        events print a single character on the screen.
 --check
        check sequence in --read, (must be used together with
        --write in another sotest-task
 --size,-s [bytes]
        use [bytes] bytes to transfer and receive data
 --count [number]
        use [number] as initial number to write with -w
 --consistence
        send alternating 8 bytes of 0xFF or 0x00 to test data
        consistence
 --remote
        do remote-read or remote-write, implemented for
        --write and --read
 ***************data transmission commands****************
 --rwtest [object1] [port1] [object2] [port2] [write-timeout] [read-timeout]
        make a write-object (object1,port1) and a read-object
        (object2,port2) with a timeout set for the 2nd object
        then write 8 bytes (values 1 to 8) and read the 2nd
        object (read immediately) and return the results
 --write,-w [object] [port] [timeout]
        write data (a running counter), non blocking
 --write-w [object] [port] [timeout]
        the same as --write but do silently retry to write
        when the driver returns a SOCAN_WAIT status.
 --writeinhibit [object] [port] [timeout] [inhibit-time]
        similar to writelater, but the CAN-object gets a timestamp
        when it is transmitted. Inhibit-time is the minumum
        time that has to pass before a new object is sent. This
        concerns only writeinhibit combined with the loop-command.
        In this case only about every [inhibit-time]
        microseconds new data will be sent (note that the unit
        for this parameter is microseconds, not milliseconds
 --read,-r [object] [port] [timeout]
        read data from an object (blocking).
 --readnow [object] [port] [timeout]
        read data from an object (immediately).
 --queue-read [port] [timeout] [object] {[object]}
        read more than one object via the signal-function in
        conjunction with the new queue-read operation
        together with --remote, all objects will be remote-read
        objects