Crates.io | esp-idf-hal |
lib.rs | esp-idf-hal |
version | 0.44.1 |
source | src |
created_at | 2019-08-02 11:47:14.146115 |
updated_at | 2024-07-09 07:04:13.861986 |
description | A Hardware abstraction layer for Espressif's ESP family of microcontrollers based on the ESP-IDF framework. |
homepage | |
repository | https://github.com/esp-rs/esp-idf-hal |
max_upload_size | |
id | 153739 |
size | 1,106,580 |
V0.2
as well as those of V1.0
- both blocking and asyncasync
mode for each driver (async
support in progress)esp-idf-sys
as esp_idf_hal::sys
You might want to also check out the ESP IDF Services wrappers, and the raw bindings to ESP IDF in the esp-idf-sys
crate!
(For baremetal Rust ESP projects please check esp-hal
.)
Follow the Prerequisites section in the esp-idf-template
crate.
The examples could be built and flashed conveniently with cargo-espflash
. To run e.g. the ledc_simple
on an e.g. ESP32-C3:
(Swap the Rust target and example name with the target corresponding for your ESP32 MCU and with the example you would like to build)
with cargo-espflash
:
$ MCU=esp32c3 cargo espflash flash --target riscv32imc-esp-espidf --example ledc_simple --monitor
MCU | "--target" |
---|---|
esp32c2 | riscv32imc-esp-espidf |
esp32c3 | riscv32imc-esp-espidf |
esp32c6 | riscv32imac-esp-espidf |
esp32h2 | riscv32imac-esp-espidf |
esp32p4 | riscv32imafc-esp-espidf |
esp32 | xtensa-esp32-espidf |
esp32s2 | xtensa-esp32s2-espidf |
esp32s3 | xtensa-esp32s3-espidf |
In order to run the examples on other chips you will most likely need to adapt at least the used pins.
Use the esp-idf-template
project. Everything would be arranged and built for you automatically - no need to manually clone the ESP IDF repository.
For more information, check out:
esp-idf-template
projectembedded-hal
projectesp-idf-svc
projectembedded-svc
projectesp-idf-sys
projectEach chip has a number of GPIO pins which are generally used by the SPI0
and SPI1
peripherals in order to connect external PSRAM and/or SPI Flash memory. The datasheets explicitly state that these are not recommended for use, however this crate includes them anyways for completeness.
Please refer to the table below to determine the pins which are not recommended for use for your chip.
Chip | GPIOs |
---|---|
ESP32 | 6 - 11, 16 - 17 |
ESP32-C2 | 12 - 17 |
ESP32-C3 | 12 - 17 |
ESP32-C6 | 24 - 30 |
ESP32-H2 | 15 - 21 |
ESP32-S2 | 26 - 32 |
ESP32-S3 | 26 - 32, 33 - 37* |
* When using Octal Flash and/or Octal PSRAM