This crate provides an autogenerated API for access to STM32F1 peripherals. The API is generated using svd2rust with patched svd files containing extensive type-safe support. For more information please see the main repo.
Refer to the documentation for full details.
Each device supported by this crate is behind a feature gate so that you only compile the device(s) you want. To use, in your Cargo.toml:
[dependencies.stm32f1]
version = "0.9.0"
features = ["stm32f100", "rt"]
The rt
feature is optional and brings in support for cortex-m-rt
.
In your code:
use stm32f1::stm32f100;
let mut peripherals = stm32f100::Peripherals::take().unwrap();
let gpioa = &peripherals.GPIOA;
gpioa.odr.modify(|_, w| w.odr0().set_bit());
For full details on the autogenerated API, please see: https://docs.rs/svd2rust/0.16.1/svd2rust/#peripheral-api
Module | Devices | Links |
---|---|---|
stm32f100 | STM32F100 | RM0041, st.com |
stm32f101 | STM32F101 | RM0008, st.com |
stm32f102 | STM32F102 | RM0008, st.com |
stm32f103 | STM32F103 | RM0008, st.com |
stm32f107 | STM32F105, STM32F107 | RM0008, st.com |