Crates.io | dlt-core |
lib.rs | dlt-core |
version | |
source | src |
created_at | 2021-05-03 13:44:57.303425+00 |
updated_at | 2025-03-19 13:11:35.453871+00 |
description | Parser and writer for autosar DLT Diagnostic Log and Trace |
homepage | |
repository | https://github.com/esrlabs/dlt-core |
max_upload_size | |
id | 392504 |
Cargo.toml error: | TOML parse error at line 18, column 1 | 18 | autolib = false | ^^^^^^^ unknown field `autolib`, expected one of `name`, `version`, `edition`, `authors`, `description`, `readme`, `license`, `repository`, `homepage`, `documentation`, `build`, `resolver`, `links`, `default-run`, `default_dash_run`, `rust-version`, `rust_dash_version`, `rust_version`, `license-file`, `license_dash_file`, `license_file`, `licenseFile`, `license_capital_file`, `forced-target`, `forced_dash_target`, `autobins`, `autotests`, `autoexamples`, `autobenches`, `publish`, `metadata`, `keywords`, `categories`, `exclude`, `include` |
size | 0 |
A library that support efficient parsing & writing log-messages encoded as Diagnositic
Log
and Trace
messages.
Add this to your Cargo.toml
:
[dependencies]
dlt_core = "0.20"
This is an example of how to parse a message and serialize it back to a byte array.
use dlt_core::dlt_parse::{dlt_message, ParsedMessage};
fn main() {
let raw1: Vec<u8> = vec![
// --------------- storage header
/* DLT + 0x01 */ 0x44, 0x4C, 0x54, 0x01,
/* timestamp sec */ 0x2B, 0x2C, 0xC9, 0x4D, /* timestamp us */ 0x7A, 0xE8, 0x01,
0x00, /* ecu id "ECU" */ 0x45, 0x43, 0x55, 0x00,
// --------------- header
/* header-type 0b0010 0001 */ 0x21,
/* extended header | |||^ */
/* MSBF: 0 little endian | ||^ */
/* WEID: 0 no ecu id | |^ */
/* WSID: 0 sess id | ^ */
/* WTMS: 0 no timestamp ^ */
/* version nummber 1 ^^^ */
/* message counter */
0x0A, /* length = 0 */ 0x00, 0x13,
// --------------- extended header
0x41, // MSIN 0b0100 0001 => verbose, MST log, ApplicationTraceType::State
0x01, // arg count
0x4C, 0x4F, 0x47, 0x00, // app id LOG
0x54, 0x45, 0x53, 0x32, // context id TES2
// --------------- payload
/* type info 0b0001 0000 => type bool */ 0x10,
0x00, 0x00, 0x00, 0x6F,
];
match dlt_message(&raw1[..], None, true) {
Ok((_rest, ParsedMessage::Item(msg))) => {
let msg_bytes = msg.as_bytes();
assert_eq!(raw1, msg_bytes);
}
_ => panic!("could not parse message"),
}
}
The parser is quite fast. Parsing a 4.8 GByte DLT file that contains over 3.5 mio messages took ~12 seconds (~409 MB/sec)
The following example can be run with cargo run --example file_parser --release sample.dlt
use dlt_core::read::{read_message, DltMessageReader};
use std::{env, fs, fs::File, path::PathBuf, time::Instant};
fn main() {
// collect input file details
let dlt_file_path = PathBuf::from(&env::args().nth(1).expect("no filename given"));
let dlt_file = File::open(&dlt_file_path).expect("open input file");
let dlt_file_size = fs::metadata(&dlt_file_path).expect("file size error").len();
// now parse all file content
let mut dlt_reader = DltMessageReader::new(dlt_file, true);
let mut message_count = 0usize;
let start = Instant::now();
while let Some(_message) = read_message(&mut dlt_reader, None).expect("read dlt message") {
message_count += 1;
}
// print some stats
let duration_in_s = start.elapsed().as_millis() as f64 / 1000.0;
let file_size_in_mb = dlt_file_size as f64 / 1024.0 / 1024.0;
let amount_per_second: f64 = file_size_in_mb / duration_in_s;
println!(
"parsing {} messages took {:.3}s! ({:.3} MB/s)",
message_count, duration_in_s, amount_per_second
);
}
empty content after 33554430 parsed messages
parsing 33554430 messages took 12.117s! (408.651 MB/s)
Below is the revised and improved English version of the documentation:
statistics
: Enables the statistics
module, which scans the source data and provides a summary of its contents. This gives you an overview of the number of messages and their content.
fibex
: Enables the fibex
module, which allows to parse configurations for non-verbose messages from a fibex model.
debug
: Adds additional log output for debugging purposes.
serialization
: Adds Serialize
and Deserialize
implementations (via serde
) to all public types. This feature is useful if you need to encode or decode these types for transmission or storage.
stream
: Provides API for parsing DLT messages from streams.
chipmunk is a cross-platform log viewer that integrates dlt-core for lightning-fast parsing and display of DLT log files. With chipmunk, you can:
If you’re looking for a user-friendly way to work with large DLT logs, give chipmunk a try!