#stack #mesh #bluetooth #full-stack #pdu #cross-platform #implemented

no-std bluetooth_mesh

Cross-platform, full Bluetooth Mesh stack implemented in Rust. Following the Bluetooth Mesh Spec Core v1.0 by SIG. Designed to work with any almost any BLE radio (uses https://github.com/AndrewGi/btle/ for platform dependent Bluetooth drivers). While a stack is provided by the library, all the primatives and objects needed to customize and create your own stack are provided. See https://github.com/AndrewGi/BluetoothMeshRust for more.

4 releases

0.1.4 Feb 22, 2020
0.1.2 Jan 13, 2020
0.1.1 Jan 12, 2020
0.1.0 Aug 19, 2019

#1341 in Hardware support

Download history 2/week @ 2024-09-23 1/week @ 2024-11-04 23/week @ 2024-12-02 33/week @ 2024-12-09

56 downloads per month

GPL-3.0-only

1MB
12K SLoC

Bluetooth Mesh Rust

Docs

Crates.io

!! WIP and API not stable until version 1.0 !!

Cross-platform, full Bluetooth Mesh stack implemented in Rust. Following the Bluetooth Mesh Spec Core v1.0 by SIG. Designed to work with any almost any BLE radio (uses https://github.com/AndrewGi/btle/ for platform dependent Bluetooth drivers). While a stack is provided by the library, all the primitives and objects needed to customize and create your own stack are provided.

This library is designed for #![no_std] in mind. However, because of the complexity of the Bluetooth Mesh Stack, std is required for the full_stack which uses async tokio for message handling and processing. #![no_std] is also disabled for now until https://github.com/rust-lang/rust/pull/69033 hits nightly/stable.

The only heap allocations made during processing a message is allocating memory for the message at the access layer. Most Mesh PDUs are <31 bytes (to fit in a single BLE Advertisement) so the Network and Lower Transport Layer stores its data statically on the stack. Upper PDUs and above allow for allocation elsewhere than the stack (Upper Transport PDUs can be up to 380 bytes!) but a custom allocator/storage for the PDU can be genericly provided.

Examples

See Mesh CLI for an application example.

How the Stack works

The flowchart of the full mesh stack

Dependencies

~3–4.5MB
~88K SLoC