esp-hal
esp-pacs
esp-hal | esp-pacs | |
---|---|---|
3 | 1 | |
565 | 91 | |
3.7% | - | |
9.8 | 8.6 | |
7 days ago | 6 days ago | |
Rust | Rust | |
Apache License 2.0 | Apache License 2.0 |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
esp-hal
-
Rust on Espressif chips – 29-09-2023
In the esp-hal, they appear to offer both sync and async I2C implementations, depending on what works best for an application. Since the async implementation is gated by a feature, it may not show up in the docs you linked.
Async implementation: https://github.com/esp-rs/esp-hal/blob/main/esp-hal-common/s...
You can also see the async feature mentioned here: https://docs.rs/crate/esp32s2-hal/latest/features
-
The Embedded Rust ESP Development Ecosystem
Going another level up the chain, we then have the hardware abstraction layer (HAL) crate. HAL crates are supposed to offer more portability and user-friendly API for a particular processor. For ESP devices the different hals are captured in the esp-hal repository. This occurs by implementing some common traits defined in what is referred to as the embedded-hal. Additionally, the device HAL attempts to incorporate mechanisms, or wrappers around lower-level functions, that are part of the Rust safety model.
-
How to write HALs and get into microcontroller programming
There is https://docs.rust-embedded.org/book/design-patterns/hal/index.html but I wonder what OP is missing in https://github.com/esp-rs/esp-hal
esp-pacs
-
The Embedded Rust ESP Development Ecosystem
The no-std ecosystem follows the same layering approach that exists within embedded Rust. In embedded Rust, there are several levels of abstraction that are introduced on top of microcontroller hardware as shown in the figure below. The first level is the peripheral access crate (PAC) which gives us access to low-level microcontroller registers at the bit level. It's also worth noting that the PAC is specific to a particular microcontroller series. For ESP devices the different PACs are captured in the esp-pacs repository. The microarchitecture crate is at a similar abstraction level to the PAC but specific to processor core (Ex. RISC-V) functions.
What are some alternatives?
esp32-phantom - ESP32 Rust-based WiFi and BLE sandbox
esp-wifi - A WiFi, Bluetooth and ESP-NOW driver for use with Espressif chips and bare-metal Rust
linux-embedded-hal - Implementation of the `embedded-hal` traits for Linux devices
esp-backtrace - backtrace for ESP32 bare-metal
esp-idf-hal - embedded-hal implementation for Rust on ESP32 and ESP-IDF
esp-storage - implementation of embedded-storage traits to access unencrypted ESP32 flash
esp-alloc - A simple `no_std` heap allocator for RISC-V and Xtensa processors from Espressif
novusk - A kernel written in Rust
esp-println - Provides print! and println! implementations various Espressif devices
atsamd - Target atsamd microcontrollers using Rust