A zero allocation rust library for basic parsing & writing DLT (Diagnostic Log and Trace) packets. Currently only the parsing and writing of the header is supported & parsing of verbose messages.
By default serde
is disabled and std
is enabled if you add dlt_parse
as dependency to your Cargo.toml
:
toml
[dependencies]
dlt_parse = "0.8.4"
If you additionally want serde
support you will have to activate the serde
feature:
toml
[dependencies]
dlt_parse = { version = "0.8.4", features = ["serde"] }
If you want to use the crate in no_std
mode you will have to disable the default features:
toml
[dependencies]
dlt_parse = { version = "0.8.4", default-features = false }
dlt_parse is a library that aims to provide serialisation & deserialisation funtions for DLT (Diagnostic Log and Trace) packets. It should make it possible to anlyse recordings of DLT packets as fast as possible, as well as writing servers that send DLT packets to the network.
Some key points are:
no-std
environment.In this example a non verbose DLT packet is serialized and deserialized again. Specificly the serialized packet is converted into a DltPacketSlice. This has the advantage, that not all fields have to be deserialied to access the payload or specific fields in the header. Note that it is also possible to completely deserialize DLT headers with the DltHeader::read function. This can make sense, if most fields of the header are used anyways.
```rust use self::dlt_parse::{DltHeader, DltLogLevel, DltExtendedHeader, SliceIterator};
let header = { let mut header = DltHeader { isbigendian: true, // payload & message id are encoded with big endian messagecounter: 0, length: 0, ecuid: None, sessionid: None, timestamp: None, extendedheader: Some(DltExtendedHeader::newnonverboselog( DltLogLevel::Debug, [b'a', b'p', b'p', b'i'],// application id [b'c', b't', b'x', b'i'],// context id )) }; header.length = header.headerlen() + 4 + 4; // header + message id + payload
header
};
// buffer to store serialized header & payload
let mut buffer = Vec::
// write payload (message id 1234 & non verbose payload) { // for write_all use std::io::Write;
// write the message id & payload
buffer.write_all(&1234u32.to_be_bytes()).unwrap(); // message id
buffer.write_all(&[5,6,7,9]); // payload
}
// packets can contain multiple dlt messages, iterate through them for dltmessage in SliceIterator::new(&buffer) { match dltmessage { Ok(dltslice) => { //check if the message is verbose or non verbose if let Some(typedpayload) = dltslice.typedpayload() { use dltparse::DltTypedPayload::*; match typedpayload { Verbose { info, iter } => { println!("verbose message of type {:?} with values:", info.intomessagetype()); for value in iter { println!(" {:?}", value); } } NonVerbose { info, msgid, payload, } => { println!( "non verbose message 0x{:x} of type {:?} and {} bytes of payload", msgid, info.map(|v| v.intomessagetype()), payload.len() ); } } } else { println!("non verbose message with incomplete message id"); } }, Err(err) => { //error parsing the dlt packet println!("ERROR: {:?}", err); } } } ```
An complete example which includes the parsing of the ethernet & udp headers can be found in examples/printmessagesids.rs
Licensed under either of Apache License, Version 2.0 or MIT license at your option. The corresponding license texts can be found in the LICENSE-APACHE file and the LICENSE-MIT file.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you shall be licensed as above, without any additional terms or conditions.