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].
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:
toml
[dependencies.stm32f1]
version = "0.2.3"
features = ["stm32f100", "rt"]
The rt
feature is optional and brings in support for cortex-m-rt
.
In your code:
```rust extern crate stm32f1; use stm32f1::stm32f100;
let mut peripherals = stm32f100::Peripherals::take().unwrap(); let gpioa = &peripherals.GPIOA; gpioa.odr.modify(|, w| w.odr0().setbit()); ```
For full details on the autogenerated API, please see: https://docs.rs/svd2rust/0.13.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 |