Crates.io | automotive_diag |
lib.rs | automotive_diag |
version | 0.1.9 |
source | src |
created_at | 2023-04-15 19:54:29.184149 |
updated_at | 2024-07-24 20:14:45.983583 |
description | Core definitions for various Automotive ECU Diagnostics such as UDS ISO-14229, KWP2000, OBD-II, etc. |
homepage | |
repository | https://github.com/nyurik/automotive_diag |
max_upload_size | |
id | 840137 |
size | 86,560 |
This crate provides low-level no_std
structs and enums of
the Unified Diagnostic Services (ISO-14229-1),
KWP2000 (ISO-142330) and
OBD-II (ISO-9141)
specifications for the road vehicles in Rust.
Not everything is implemented yet, but the goal is to provide a full set of enums and structs to handle the most common diagnostic commands and responses. If you need a specific command or response, please open an issue or better yet, a pull request.
All values are presented as Rust enum
, and can be converted to/from their underlying numeric values using
the T::from_repr(u8)
and u8::from(value)
. Most enums also have a corresponding ...Byte
enums as ByteWrapper<T>
to
handle the non-standard Extended(u8)
values in addition to the defined Standand(T)
ones.
use automotive_diag::ByteWrapper::{Extended, Standard};
use automotive_diag::uds::UdsCommand::{DiagnosticSessionControl, ECUReset};
use automotive_diag::uds::UdsCommandByte;
/// Handle a single command byte on the ECU side
fn handle_cmd_byte(cmd: u8) {
match UdsCommandByte::from(cmd) {
Standard(DiagnosticSessionControl) => {
// handle_diag_session()
}
Standard(ECUReset) => {
// handle_ecu_reset()
}
Extended(0x42) => {
// handle_custom_cmd_42()
}
_ => {
// handle all other commands
}
}
}
make
.
Install it with cargo install just
.just
.just test
.git push
, it will run a few validations, including cargo fmt
, cargo clippy
, and cargo test
.
Use git push --no-verify
to skip these checks.The code was forked from the amazing rnd-ash/ecu_diagnostics project. The code was forked from the last MIT-versioned code before the MIT to GPL license migration. Initially, this code was developed as a deprecated auto_uds crate.
Licensed under either of
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.