device-envoy
Build Pico applications with LED panels, easy WiFi, and composable device abstractions.
device-envoy is a library for building embedded applications in Rust, built on the Embassy framework. It organizes hardware around device abstractions.
A device abstraction is a software encapsulation of hardware that manages timing, tasks, control flow, interrupts, channels, and state within the abstraction.
Rather than replacing HALs or drivers, device-envoy builds on them. It defines device abstractions that expose a small set of simple operations to the rest of the program.
Currently targeting Raspberry Pi Pico 1 and Pico 2 (ARM cores). RISC-V core support exists but is not actively tested.
Start From a Template
Want a minimal starting project? Use device-envoy-blinky on GitHub as a template.
Status
⚠️ Alpha / Experimental
The API is actively evolving. Not recommended for production use, but excellent for experimentation, learning, and exploratory projects.
Features
todo000 add audio-player
- LED Strips & Panels - NeoPixel-style (WS2812) LED arrays with 2D text rendering, animation, embedded-graphics support. Provides efficient options for power limiting and color correction.
- WiFi (Pico W) - Connect to the Internet with automatic credentials management. On boot, opens a web form if WiFi credentials aren't saved, then connects seamlessly to a stored network. Requires Pico W; WiFi is not supported on non-W boards.
- Audio Player - Play audio clips over I2S hardware with runtime volume control.
- Button Input - Button handling with debouncing
- Servo Control - Servo positioning and animation
- Flash Storage - Type-safe, on-board persist storage
- LCD Display - Text display (HD44780)
- IR Remote - Remote control decoder (NEC protocol)
- RFID Reader - Card detection and reading (MFRC522)
- Clock Sync - Network time synchronization utilities
- LED4 Display - 4-digit, 7-segment LED display control with optional animation and blinking
- Single LED - Single digital LED control with animation support
Forum
- Using Embassy to build applications
A place to talk about writing embedded applications with Embassy: sharing code, asking practical questions, and learning what works in practice.
Not limited to Pico boards or todevice-envoy.
Articles
- How Rust & Embassy Shine on Embedded Devices by Carl M. Kadie and Brad Gibson.
- More Rust articles
Examples & Demos
The project includes examples (single-device tests) in examples/ and demo applications in demos/ showing integration patterns:
Example: animated LED strip
This example cycles a 96-LED strip through red, green, and blue frames.

It shows how device-envoy generates a struct (device abstraction) for an LED strip and then animates a sequence of frames.
#
#
# use panic_probe as _;
# use Infallible;
use ;
use led_strip;
led_strip!
async
For complete, runnable examples (including wiring and setup), see the
examples/anddemos/directories.
-
Basic LED Examples: Simple on/off control with blinky pattern
-
LED Strip Examples: Simple animations, color control, text rendering
-
LED Panel Examples: 12×4, 12×8, and multi-panel configurations with graphics

- Button Examples: Debouncing and state handling
- Servo Examples: Position sweeps and animation playback
- WiFi Examples: WiFi setup, time sync, DNS
- Flash Examples: Configuration persistence and data reset
See the examples/ and demos/ directories for complete runnable code.
Building & Running
Prerequisites
# Add Rust targets for Pico boards
Quick Start
# New project template
# https://github.com/CarlKCarlK/device-envoy-blinky
# Run examples using convenient aliases
# Check without running (faster builds)
# Build and check everything
Tools:
just- Optional command runner (install withcargo install justor your package manager). Seejustfilefor commands.xtask- Project's custom automation tool (built-in, use viacargo xtask --help)
See .cargo/config.toml for all cargo aliases.
Hardware Notes
Standard Pinouts
Examples use conventional pin assignments for consistency:
- PIN_0: LED strip (8-pixel simple example)
- PIN_1: Single LED (blinky patterns) - Built-in LEDs are modeled as active-high (OnLevel::High) on all supported boards
- PIN_3: LED panel (12×4, 48 pixels)
- PIN_4: Extended LED panel (12×8, 96 pixels)
- PIN_5: Long LED strip (160 pixels, broadway/marquee effects)
- PIN_6: Large LED panel (16×16, 256 pixels)
- PIN_8: I2S audio output data pin (
DIN) - PIN_9: I2S audio output bit clock pin (
BCLK) - PIN_10: I2S audio output word select pin (
LRC/LRCLK) - PIN_13: Button (active-low)
- PIN_11, PIN_12: Servo signals
Testing
Host-side tests run on your development machine without hardware:
just is the optional command runner (install with cargo install just or your package manager). See Tools above.
Tests include:
- LED text rendering comparisons against reference images
- 2D LED matrix mapping algebra
- LED color space conversions
Policy on AI-assisted development and contributions
The use of AI tools is permitted for development and contributions to this repository. AI may be used as a productivity aid for drafting, exploration, and refactoring.
All code and documentation contributed to this repository must be reviewed, edited, and validated by a human contributor. AI tools are not a substitute for design judgment, testing, or responsibility for correctness.
AGENTS.md contains the general instructions and constraints given to AI tools used during development of this repository.
License
Licensed under either:
- MIT license (see LICENSE-MIT file)
- Apache License, Version 2.0
at your option.