#hardware-abstraction #hal #cortex-m #arm #py32f0xx

no-std py32f0xx-hal

Peripheral access API for py32F0 series microcontrollers

3 unstable releases

0.1.1 Oct 10, 2024
0.1.0 Sep 27, 2024
0.0.1 Jun 10, 2023

#168 in Embedded development

Download history 4/week @ 2024-09-18 135/week @ 2024-09-25 22/week @ 2024-10-02 162/week @ 2024-10-09 6/week @ 2024-10-16

146 downloads per month

0BSD license

170KB
3.5K SLoC

py32f0xx-hal

This repo is modified from stm32f0xx-hal

NOTE: The function is not fully tested, and you are responsible for any problems with the use of this repository.

Known issue: - I2C not work

Continuous integration Crates.io docs.rs

py32f0xx-hal contains a hardware abstraction on top of the peripheral access API for the puyasemi PY32F0xx family of microcontrollers.

Collaboration on this crate is highly welcome, as are pull requests!

Supported

  • py32f030 (py32f030xx4, py32f030xx6, py32f030xx7, py32f030xx8)
  • py32f003 (py32f003xx4, py32f003xx6, py32f030xx8)
  • py32f002a (py32f002ax5)
  • py32f002b (py32f002bx5)

Getting Started

The examples folder contains several example programs. To compile them, one must specify the target device as cargo feature:

$ cargo build --features=py32f002ax5 --example=blinky

To use py32f0xx-hal as a dependency in a standalone project the target device feature must be specified in the Cargo.toml file:

[dependencies]
cortex-m = "0.7.7"
cortex-m-rt = "0.7.3"
py32f0xx-hal = { version = "0.1.0", features = ["py32f002ax5"]}

If you are unfamiliar with embedded development using Rust, there are a number of fantastic resources available to help.

Minimum supported Rust version

The minimum supported Rust version is the latest stable release. Older versions may compile, especially when some features are not used in your application.

Changelog

See CHANGELOG.md.

License

0-Clause BSD License, see LICENSE-0BSD.txt for more details.

Dependencies

~9MB
~216K SLoC