8 breaking releases

0.10.0 Jun 7, 2024
0.8.0 Feb 9, 2024
0.7.0 Oct 11, 2023
0.6.0 Sep 13, 2022
0.4.0 Jul 15, 2022

#699 in Hardware support

Download history 45/week @ 2024-09-11 51/week @ 2024-09-18 56/week @ 2024-09-25 16/week @ 2024-10-02 55/week @ 2024-10-09 25/week @ 2024-10-16 1/week @ 2024-10-23 15/week @ 2024-10-30 10/week @ 2024-11-06 2/week @ 2024-11-13 6/week @ 2024-11-20 3/week @ 2024-11-27 29/week @ 2024-12-04 59/week @ 2024-12-11 16/week @ 2024-12-18

104 downloads per month
Used in py32f030_hal

MIT license

150KB
78 lines

Crates.io Documentation tests

defmt-serial

A defmt target for logging over a serial port. Have a look at examples to see how to use library example-artemis or example-pi-pico. You can also try it out in a hosted environment: example-std. To parse the logs have a look at parsing logs.

static SERIAL: StaticCell<hal::uart::Uart0> = StaticCell::new();

#[entry]
fn main() -> ! {
    let mut dp = hal::pac::Peripherals::take().unwrap();
    let pins = hal::gpio::Pins::new(dp.GPIO);

    // set up serial
    let serial = hal::uart::Uart0::new(dp.UART0, pins.tx0, pins.rx0);
    defmt_serial::defmt_serial(SERIAL.init(serial));

    defmt::info!("Hello from defmt!");

    loop {
        asm::wfi();
    }
}

Remember to set the DEFMT_LOG variable when testing, e.g.:

$ cd example-std/
$ DEFMT_LOG=debug cargo run

Parsing logs

The easiest way to parse the logs is to use socat and defmt-print together. For example:

$ socat ${PORT},rawer,b${BAUDRATE} STDOUT | defmt-print -e ${ELF}

Just replace ${PORT}, ${BAUDRATE} and ${ELF} with correct values.

To install the tools on Ubuntu 22.04 run these commands:

$ apt install socat
$ cargo install defmt-print

Note that on Mac OS it seems that socat is broken for this purpose. Use stty and cat in stead:

$ (stty speed 115200 >/dev/null && cat) </dev/cu.usbserial-10 | defmt-print -e $(ELF)

Dependencies

~0.6–1MB
~23K SLoC