#scd30 #sensirion #driver #scd41 #scd40

no-std libscd

Rust drivers for various SCD devices such as scd30 and scd4x CO2 sensors

7 releases (4 breaking)

0.4.0 Dec 23, 2024
0.3.1 Jun 1, 2024
0.3.0 Apr 16, 2024
0.2.1 Apr 11, 2024
0.0.0 Mar 28, 2024

#189 in Embedded development

Download history 14/week @ 2024-09-25 6/week @ 2024-10-02 7/week @ 2024-10-09 5/week @ 2024-10-16 1/week @ 2024-10-23 1/week @ 2024-10-30 2/week @ 2024-11-06 2/week @ 2024-11-13 9/week @ 2024-11-20 14/week @ 2024-11-27 18/week @ 2024-12-04 23/week @ 2024-12-11 126/week @ 2024-12-18 32/week @ 2024-12-25 18/week @ 2025-01-01 14/week @ 2025-01-08

191 downloads per month

MIT/Apache

100KB
1.5K SLoC

Lib SCD

License Version Downloads Build

LibSCD is s Rust driver implementation for SCD30, SCD40 and SCD41 sensors using the embedded-hal and embedded-hal-async interfaces.

Usage

Add the crate as a dependency in Cargo.toml and select the required features:

[dependencies.libscd]
version = "0.4"
features = ["defmt", "sync", "scd40"]

Then we can start consuming data from SCD40 using blocking I2C communication:

#[embassy_executor::main]
async fn main(_spawner: Spawner) {
    let p = embassy_stm32::init(Default::default());

    let i2c = I2c::new(
        p.I2C2,
        p.PB10,
        p.PB3,
        Irqs,
        NoDma,
        NoDma,
        Hertz(100_000),
        Default::default(),
    );

    let mut scd = Scd40::new(i2c, Delay);

    // When re-programming, the controller will be restarted,
    // but not the sensor. We try to stop it in order to
    // prevent the rest of the commands failing.
    _ = scd.stop_periodic_measurement();

    info!("Sensor serial number: {:?}", scd.serial_number());
    if let Err(e) = scd.start_periodic_measurement() {
        defmt::panic!("Failed to start periodic measurement: {:?}", e);
    }

    loop {
        if scd.data_ready().unwrap() {
            let m = scd.read_measurement().unwrap();
            info!("CO2: {}\nHumidity: {}\nTemperature: {}", m.co2, m.humidity, m.temperature)
        }

        Delay.delay_ms(1000)
    }
}

Crate Feature Flags

The support for each sensor and sync/async mode is controlled by a feature:

Feature Description
sync Enables the blocking driver implementation for the selected sensors
async Enables the async driver implementation for the selected sensors
scd30 Enables the driver for the SCD30 sensor
scd40 Enables the driver for the SCD40 sensor
scd41 Enables the driver for the SCD41 sensor
defmt Derive defmt::Format for the error type

License

The project is dual licensed under MIT or APACHE-2.0

Dependencies

~175KB