This is a collection of things that are not yet awesome in Embedded Rust. We need your help to capture all of the things that are not yet awesome, and to start making them awesome!
This project is developed and maintained by the Resources team.
Are you interested in:
Check out our Contributing Guide for how to get started.
And don't forget to check our Awesome Embedded Rust list! The thing you are looking for may already exist!
Currently, it is not convenient to share non-atomic or non-Sync
data with an interrupt using safe Rust. Because interrupt handlers are functions that take no arguments, all data consumed by interrupts must either be global or module scoped Atomics (e.g. AtomicBool
), local static
variables, or global or module scoped static
variables.
Global variables are not great in Rust, because:
Sync
/Atomic
data) must be unsafe
const
context, so it's often necessary to use an Option<T>
to delay the initialization to runtimeFrameworks like cortex-m-rtic achieve this in a zero cost fashion by using a Domain Specific Language to automatically provide safe access to shared resources between tasks and interrupts, however these tools can not be used by applications not using RTIC, or by libraries such as HAL or BSP crates.
Useful Links
Ideally, we would be able to support all of the following use cases:
We should be able to serve the three use cases listed above, while:
no_std
For embedded systems that send or receive data to other devices, or who read/write data to a medium such as an SD card or other Flash memory, it is useful to have automatic serialization and deserialization support to turn structured data into a binary format.
While tools like serde
are widely used in Rust (and already support no_std
), few of the the backends (like serde_json
) are supported in a no_std
environment.
We should be able to serialize and deserialize data in an automatic way, either using a frontend like serde
, or with a simple and convenient serialize
and deserialize
method. To use these, we should not need heap allocations, and it should be possible to detect when serialization and deserialization have failed.
Additionally, all common datatypes used in embedded Rust should be supported, as well as a (preferrably automatic) way to add support for custom data types. Common data types include:
u8..u64
or i8..i64
f32..f64
[u8]
and &str
We should also have support for different ways of serializing data, primarily:
serde
already has support for no_std
environments, when using a feature flag
ssmarshal
has support for basic types, but does not support enums with more than 255 variants, or variable sized types like slices. This covers only the non-self-describing use case.
ujson
supports JSON serialization and deserialization for no_std
environments, but is experimental (and not on crates.io), and is unlikely to be stabilized as-is
std
-only serde
backends, though they do not seem to have official support from the upstream libraries. These forks include:
The USB standard has a fair bit of commonality between USB Devices (like Mice, Printers, and Webcams) and USB Hosts (like Laptops and Raspberry Pis), but each specific microcontroller has a slightly different implementation of the USB Controller at the bottom of the stack. It would make bringing up a USB stack on a new chip much easier if there was a #[no_std]
crate which defined some common traits, enumerations and structures at the bottom, and then provided support for various device classes above that.
I'd like to be able to implement USB Host and USB Device support on the Texas Instruments Tiva-C line and the STM32F4 line by only implementing a thin shim around each device's USB OTG Controller registers. The USB Host should be able to handle a USB Keyboard and the USB Device should enumerate as a Communications Class Device (two of the most common use-cases).
usb-device
usb-device
to implement its own HID support for USB keyboard firmware.
This project usually serves as a starting point for those willing to implement their own USB keyboard firmware.So far there seem to be no libraries to do anything with displays or gui's. However in C some libraries have already been written. Rust could interface with these libraries if bindings were made.
Bindings to C libraries or a Rust library that is meant for Displays and/or GUIs.
There is a large amount of accessible libraries and projects involving the esp32-cam in c++, and a few projects for rust using esp-idf-std (listed below), however there are no no_std crates with this support. A repository of information, including pin defintions, can be found (here)[https://github.com/raphaelbs/esp32-cam-ai-thinker/blob/master/docs/esp32cam-pin-notes.md].
A library with bindings to the esp32-cam camera, accessible in a no_std environment.
Here's an example for something that is not yet awesome:
IETF RFC -1 states that you should be able to Foo with either a Bar, Bib, Bim, or Bap. However in all of these rust crates, you're required to have a Bar!
I'd like to be able to Foo using only a Bib, Bim, or Bap.
foobar
crate is on on githubThe Not Yet Awesome Embedded Rust list (this project) is distributed under the terms of the Creative Commons CC-BY-SA v4.0 license.
Copies of the license used by this project may also be found here: CC-BY-SA v4.0 Hosted.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you shall be licensed as above, without any additional terms or conditions.
Contribution to this crate is organized under the terms of the Rust Code of Conduct, the maintainers of this crate, the Resources team, promises to intervene to uphold that code of conduct.