Crates.io | j1939 |
lib.rs | j1939 |
version | 0.1.33 |
source | src |
created_at | 2024-02-11 14:02:09.942085 |
updated_at | 2024-06-10 13:08:32.16168 |
description | SAE J1939 is a set of standards that define how ECUs communicate via the CAN bus in heavy-duty vehicles. |
homepage | |
repository | https://github.com/Laixer/J1939 |
max_upload_size | |
id | 1135855 |
size | 232,673 |
A Rust crate for the SAE J1939 automotive protocol.
Build a J1939 frame with PGN 'address claimed'.
let id = j1939::IdBuilder::from_pgn(j1939::PGN::AddressClaimed)
.priority(3)
.sa(0x11)
.da(0xff)
.build();
let frame = j1939::FrameBuilder::new(id)
.copy_from_slice(&name.to_bytes()[..])
.build();
Note that this just an example and not the actual 'address claimed' frame as specified by the SAE J1939 standard.
Some common PGNs have defined data structures. For example the Time/Date PGN is fully implemented.
let timedate = j1939::spn::TimeDate {
year: 2024,
month: 4,
day: 20,
hour: 10,
minute: 1,
second: 58,
};
let id = j1939::IdBuilder::from_pgn(j1939::PGN::TimeDate)
.sa(0x28)
.build();
let frame = j1939::FrameBuilder::new(id)
.copy_from_slice(&timedate.to_pdu())
.build();
Example
$ cargo run --example j1939decode 0x0CB34A29
This runs a J1939 ID decoder on the ID '0x0CB34A29'. Each of the J1939 aid properties can be accessed with this crate.
This crate supports no_std. By default the crate creates no_std targets which means you can use the J1939 crate on embedded systems that do not support dynamic allocation.
All feedback welcome. Feel free to file bugs, requests for documentation and any other feedback to the [issue tracker][issues].
J1939 is distributed under the terms of GPL-3.0.
See LICENSE for details.