#va108xx #hal #cortex-m #vorago #aerospace #no-std

no-std va108xx-embassy

Embassy-rs support for the Vorago VA108xx family of microcontrollers

3 releases

new 0.1.2 Feb 13, 2025
0.1.1 Feb 13, 2025
0.1.0 Feb 13, 2025

#2224 in Embedded development

Apache-2.0

260KB
5K SLoC

Crates.io docs.rs

Embassy-rs support for the Vorago VA108xx MCU family

This repository contains the embassy-rs support for the VA108xx family. Currently, it contains the time driver to allow using embassy-rs. It uses the TIM peripherals provided by the VA108xx family for this purpose.

The documentation contains more information on how to use this crate.


lib.rs:

Embassy-rs support for the Vorago VA108xx MCU family

This repository contains the embassy-rs support for the VA108xx family. Currently, it contains the time driver to allow using embassy-rs. It uses the TIM peripherals provided by the VA108xx family for this purpose.

Usage

This library only exposes the embassy::init method which sets up the time driver. This function must be called once at the start of the application.

This implementation requires two TIM peripherals provided by the VA108xx device. The user can freely specify the two used TIM peripheral by passing the concrete TIM instances into the embassy::init_with_custom_irqs and embassy::init method.

The application also requires two interrupt handlers to handle the timekeeper and alarm interrupts. By default, this library will define the interrupt handler inside the library itself by using the irq-oc30-oc31 feature flag. This library exposes three combinations:

You can disable the default features and then specify one of the features above to use the documented combination of IRQs. It is also possible to specify custom IRQs by importing and using the [embassy_time_driver_irqs] macro to declare the IRQ handlers in the application code. If this is done, embassy::init_with_custom_irqs must be used method to pass the IRQ numbers to the library.

Examples

embassy example projects

Dependencies

~5.5MB
~102K SLoC