#micro-bit #wukong

no-std mb2-wukong-expansion

Board crate for Elecfreaks Wukong Extension for the BBC micro:bit v2

2 releases

0.1.2 Aug 25, 2024
0.1.1 Aug 20, 2024

#253 in Hardware support

Custom license

28KB
459 lines

Maintenance crates-io api-docs dependency-status

mb2-wukong-expansion: Rust for the Elecfreaks Wukong Expansion Board for the BBC micro:bit v2

Copyright © 2024 Bart Massey (Version 0.1.2)

This Rust crate provides support for the Elecfreaks Wukong Expansion Board (Wukong; see also their wiki) for the BBC micro:bit v2 (MB2).

This crate is currently built atop nrf52833-hal and is probably best used with that.

The Wukong provides a rechargeable battery that can power itself and the MB2, and provides expansion pins for 5V and for the MB2 edge connector.

The Wukong also provides five mostly-disjoint features visible from the MB2. Each is supported by a separate Cargo feature listed here. (All features are on by default, but you can turn off the ones you don't want to save a little space.) The names were mostly taken from the Wukong documentation.

  • "Ambient" LEDs (ambient): Four WS2812 RGB "Smart LEDs" sit at the four corners of the Wukong. This crate will drive these LEDs as if they were directly addressable.

  • "Buzzer" (buzzer): A speaker sits on the bottom of the board. This crate will play a square wave at a given frequency on this speaker.

  • Mood Lights (mood_lights): There are blue LEDs under the board that are cooperatively controlled by the Wukong and the MB2. (These are referred to as "Breath" in the Wukong documentation, but they can be put in steady-on mode as well.) This crate can run these.

  • Motor (motor): The Wukong has two DC motor controllers with pins on the board. This crate can set the speed of these motors.

  • Servo (servo): The Wukong has eight servo controllers with pins on the board. This crate can set the angle of these servos.

License

This work is licensed under the "MIT License". Please see the file LICENSE.txt in this distribution for license terms.

Acknowledgments

Thanks to Elecfreaks for doing this board, and to the folks who wrote the Micropython and PTX Javascript that I cribbed the I2C protocol from.

Spelling

Is it "WuKong" or "Wukong"? Elecfreaks seems to randomly switch between the two capitalizations in their products, so I won't worry about it much: I haven't been consistent either.

Dependencies

~13MB
~311K SLoC