#embedded-hal-driver #onewire #1wire

no-std one-wire-bus

A Rust implementation of the 1-Wire protocol for embedded-hal

2 releases

0.1.1 Jan 18, 2020
0.1.0 Jan 17, 2020

#991 in Embedded development

Download history 130/week @ 2024-09-02 129/week @ 2024-09-09 92/week @ 2024-09-16 209/week @ 2024-09-23 48/week @ 2024-09-30 24/week @ 2024-10-07 37/week @ 2024-10-14 39/week @ 2024-10-21 42/week @ 2024-10-28 37/week @ 2024-11-04 64/week @ 2024-11-11 26/week @ 2024-11-18 75/week @ 2024-11-25 52/week @ 2024-12-02 77/week @ 2024-12-09 64/week @ 2024-12-16

273 downloads per month
Used in ds18b20

MIT/Apache

20KB
385 lines

One-Wire Bus

Build Status crates.io API

A Rust implementation of the 1-Wire protocol for embedded-hal

Quick Start

These examples omit error handling to keep them short. You should check all results and handle them appropriately.

The 1-wire bus requires a single digital pin that is configured as an open-drain output (it's either open, or connected to ground), and the bus should have a ~5K Ohm pull-up resistor connected. How you obtain this pin from your specific device is up the the embedded-hal implementation for that device, but it must implement both InputPin and OutputPin

use embedded_hal::blocking::delay::DelayUs;
use embedded_hal::digital::v2::{InputPin, OutputPin};
use core::fmt::{Debug, Write};
use one_wire_bus::OneWire;

fn find_devices<P, E>(
    delay: &mut impl DelayUs<u16>,
    tx: &mut impl Write,
    one_wire_pin: P,
)
    where
        P: OutputPin<Error=E> + InputPin<Error=E>,
        E: Debug
{
    let mut one_wire_bus = OneWire::new(one_wire_pin).unwrap();
    for device_address in one_wire_bus.devices(false, delay) {
        // The search could fail at any time, so check each result. The iterator automatically
        // ends after an error.
        let device_address = device_address.unwrap();

        // The family code can be used to identify the type of device
        // If supported, another crate can be used to interact with that device at the given address
        writeln!(tx, "Found device at address {:?} with family code: {:#x?}",
                 device_address, device_address.family_code()).unwrap();
    }
}

Example Output

Found device at address E800000B1FCD1028 with family code: 0x28
Found device at address 70000008AC851628 with family code: 0x28
Found device at address 0B00000B20687E28 with family code: 0x28
Found device at address 5700000B2015FF28 with family code: 0x28

Dependencies

~71KB