#tokio #linux #sockets #socketcan

tokio-socketcan

Asynchronous Linux SocketCAN sockets with tokio

3 releases

✓ Uses Rust 2018 edition

0.1.2 Feb 8, 2019
0.1.1 Jan 10, 2019
0.1.0 Jan 10, 2019

#76 in Email

Download history 10/week @ 2019-01-05 16/week @ 2019-01-12 5/week @ 2019-01-19 9/week @ 2019-01-26 6/week @ 2019-02-02

16 downloads per month

MIT license

13KB
210 lines

crates.io badge documentation

tokio-socketcan

SocketCAN support for tokio based on the socketcan crate.

Example echo server

use futures::stream::Stream;
use futures::future::{self, Future};

let socket_rx = tokio_socketcan::CANSocket::open("vcan0").unwrap();
let socket_tx = tokio_socketcan::CANSocket::open("vcan0").unwrap();

tokio::run(socket_rx.for_each(move |frame| {
    socket_tx.write_frame(frame)
}).map_err(|_err| {}));

Testing

Integrating the test into a CI system is non-trivial as it relies on a vcan0 virtual can device existing. Adding one to most linux systems is pretty easy with root access but attaching a vcan device to a container for CI seems difficult to find support for.

To run the tests locally, though, setup should be simple:

sudo modprobe vcan
sudo ip link add vcan0 type vcan
sudo ip link set vcan0 up
cargo test

Changelog

0.1.2

  • Added futures::sink::Sink implementation for the CANSocket

Dependencies

~3MB
~52K SLoC