stm32l0xx-hal is a Hardware Abstraction Layer (HAL) for the STMicro STM32L0xx family of microcontrollers.
This crate relies on Adam Greig's stm32l0 crate to provide appropriate register definitions and implements a partial set of the embedded-hal traits.
Based on the stm32l1xx-hal crate by Vitaly Domnikov and the stm32f4xx-hal crate by Daniel Egger.
Add the stm32l0xx-hal
crate to your
dependencies in Cargo.toml
and make sure to pick the appropriate mcu-*
Cargo feature to enjoy the full feature set for your MCU (see next section
"Supported Configurations" for more details).
For example, when using the STM32L071KBTx MCU:
[dependencies]
stm32l0xx-hal = { version = "0.6.2", features = ["mcu-STM32L071KBTx", "rt"] }
The STM32L0 family consists of different subfamilies with different peripherals
and I/O configurations. Superficially, the family can be grouped into the
groups stm32l0x1
, stm32l0x2
and stm32l0x3
. However, some aspects like
alternate function mappings for I/O pins do not follow these groups.
In order for the HAL to properly support all those MCUs, we generate some peripheral mappings and corresponding Cargo features using cube-parse.
The easiest way for you to get started, is to use your appropriate mcu-*
feature. For example, when using the STM32L071KBTx MCU, you just set the
mcu-STM32L071KBTx
feature in Cargo.toml
:
# Cargo.toml
[dependencies]
stm32l0xx-hal = { version = "0.6.2", features = ["mcu-STM32L071KBTx", "rt"] }
If you take a look at the Cargo.toml
file, you
can see that mcu-STM32L071KBTx
is just an alias for ["io-STM32L071", "stm32l0x1", "lqfp32"]
.
The io-*
features are based on the GPIO peripheral version. This determines
the pin function mapping of the MCU. The features seem to correspond to the
product categories.
Right now, the following features are supported:
io-STM32L021
(Product category 1)io-STM32L031
(Product category 2)io-STM32L051
(Product category 3)io-STM32L071
(Product category 5)
The product categories should be listed in your MCU family datasheet. The name
of the io-*
feature itself is derived from the internal name used in the
STM32CubeMX database. It does not necessarily match the name of the MCU,
for example the STM32L062K8Tx
uses the GPIO peripheral version named
io-STM32L051
.
In order to use this HAL, you need the following Setup:
-
Install Rustup
See rustup.rs for details. You may als be able to install Rustup directly through your distro.
-
Install the
arm-none-eabi
compiler toolchainhttps://developer.arm.com/open-source/gnu-toolchain/gnu-rm/downloads
If you cannot install the toolchain directly through your OS / distro, we recommend installing the precompiled binaries to '/usr/local/opt'. Add the bin folders (/bin & /arm-none-eabi/bin) to your environments variable 'PATH'.
-
Install the
thumbv6m-none-eabi
target for RustSimply run
rustup target add thumbv6m-none-eabi
For more instructions on how to get started with ARM / Cortex-M programming using Rust, check out the Embedded Rust Book.
You can build examples through Cargo:
$ cargo build --release --examples --features stm32l0x1,rt
Note that not all examples are compatible with all MCUs. You might need to peek into the example source code.
The following instructions outline how-to on flashing the 'serial' example code. This can be extended to any other example code.
- Flash the microcontroller using the flash script
$ ./flash.sh target/thumbv6m-none-eabi/release/examples/serial
- Flash the microcontroller using the openocd flash script
$ ./openocd_flash.sh target/thumbv6m-none-eabi/release/examples/serial
-
Terminal 1 - OpenOCD Session:
$ ./openocd_session.sh
-
Terminal 2 - GDB Session:
$ ./gdb_session.sh target/thumbv6m-none-eabi/release/examples/serial
-
Terminal 1 - OpenOCD Session:
$ ./openocd_session.sh
-
Terminal 2 - GDB Py Session:
$ ./gdb_session.sh target/thumbv6m-none-eabi/release/examples/serial -d
Note: Users can redirect the dashboard output to separate terminal (i.e. - ttys001) using:
>>> dashboard -output /dev/ttys001
- Revert local dependencies to external cargo and uncomment configurations before committing
0-Clause BSD License, see LICENSE-0BSD.txt for more details.