Skip to content

Microbit async BSP (Board Support Package) for the BBC micro:bit v2 and newer

Notifications You must be signed in to change notification settings

lulf/microbit-bsp

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

81 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

microbit-bsp

CI crates.io docs.rs

microbit-bsp is a board support package (BSP) library for the BBC micro:bit v2 and newer.

Features

  • LED display driver with fonts
  • Uses embassy-nrf HAL for peripherals
  • Rust Async/Await

Example application

#![no_std]
#![no_main]

use {defmt_rtt as _, panic_probe as _};

use microbit_bsp::*;

use {
    embassy_executor::Spawner,
    embassy_futures::select::{select, Either},
    embassy_time::Duration,
};

#[embassy_executor::main]
async fn main(_spawner: Spawner) {
    let board = Microbit::default();

    let mut display = board.display;
    let mut btn_a = board.btn_a;
    let mut btn_b = board.btn_b;

    display.set_brightness(display::Brightness::MAX);
    display.scroll("Hello, World!").await;
    defmt::info!("Application started, press buttons!");
    loop {
        match select(btn_a.wait_for_low(), btn_b.wait_for_low()).await {
            Either::First(_) => {
                display
                    .display(display::fonts::ARROW_LEFT, Duration::from_secs(1))
                    .await;
            }
            Either::Second(_) => {
                display
                    .display(display::fonts::ARROW_RIGHT, Duration::from_secs(1))
                    .await;
            }
        }
    }
}

Examples

To run an example:

cd examples/display
cargo run --release

Cargo Features

The feature defmt is enabled by default, and allows some crates to print things.

About

Microbit async BSP (Board Support Package) for the BBC micro:bit v2 and newer

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages