Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lobaro/FreeRTOS-rust
Rust crate for FreeRTOS
https://github.com/lobaro/FreeRTOS-rust
embedded freertos nrf9160 rtos rust stm32
Last synced: 3 months ago
JSON representation
Rust crate for FreeRTOS
- Host: GitHub
- URL: https://github.com/lobaro/FreeRTOS-rust
- Owner: lobaro
- License: mit
- Created: 2020-04-10T09:02:29.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-03-26T01:59:25.000Z (10 months ago)
- Last Synced: 2024-04-14T12:01:50.204Z (9 months ago)
- Topics: embedded, freertos, nrf9160, rtos, rust, stm32
- Language: Rust
- Size: 1.14 MB
- Stars: 315
- Watchers: 16
- Forks: 54
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- rust-embedded - FreeRTOS-rust
- awesome-embedded-rust - FreeRTOS-rust
- awesome-rust-list - lobaro/FreeRTOS-rust - rust?style=social"/> : This project is based on code from [freertos.rs](https://github.com/hashmismatch/freertos.rs) and some additions to simplify the usage of [FreeRTOS](https://github.com/FreeRTOS/FreeRTOS-Kernel) in embedded applications written in Rust. (Embedded Development)
- awesome-rust-list - lobaro/FreeRTOS-rust - rust?style=social"/> : This project is based on code from [freertos.rs](https://github.com/hashmismatch/freertos.rs) and some additions to simplify the usage of [FreeRTOS](https://github.com/FreeRTOS/FreeRTOS-Kernel) in embedded applications written in Rust. (Embedded Development)
README
# FreeRTOS-rust
This project is based on code from [freertos.rs](https://github.com/hashmismatch/freertos.rs) and some additions to
simplify the usage of [FreeRTOS](https://github.com/FreeRTOS/FreeRTOS-Kernel) in embedded applications written
in Rust.In contrast to freertos.rs this crate differs in these points:
- The application `main()` entry point is written in Rust.
- The FreeRTOS scheduler can be started from Rust.
- The FreeRTOS heap `MemMang/heap/heap_x.c`is used as global memory allocator for Rust
- No need for a Clang skeleton project## How it works
The `freertos-cargo-build` build-dependency compiles the FreeRTOS code from its original "C" sources files into an
archive to be linked against your Rust app. Internally it uses the [cc crate](https://docs.rs/crate/cc) and some meta
info provided by your apps `build.rs`:
1. A path to the [FreeRTOS](https://github.com/FreeRTOS/FreeRTOS-Kernel) `Sources`
1. A path to the app specific `FreeRTOSConfig.h`
1. A relative path to the `FreeRTOS port` to be used, e.g. for ARM Cortex-M3 cores.
1. Optional: Additional C code to be compiled
The `freertos-rust` dependency provides an interface to access all FreeRTOS functionality from your (embedded)
Rust app.
## Usage1. Checkout FreeRTOS: https://github.com/FreeRTOS/FreeRTOS-Kernel
1. Add dependencies to your Rust apps `Cargo.toml`
```
[dependencies]
freertos-rust = "*"
[build-dependencies]
freertos-cargo-build = "*"
```
1. Add this snippet to your apps `build.rs`:
```
fn main() {
let mut b = freertos_cargo_build::Builder::new();
// Path to FreeRTOS kernel or set ENV "FREERTOS_SRC" instead
b.freertos("path/to/FreeRTOS-Kernel");
b.freertos_config("src"); // Location of `FreeRTOSConfig.h`
b.freertos_port("GCC/ARM_CM3"); // Port dir relativ to 'FreeRTOS-Kernel/portable'
b.heap("heap_4.c"); // Set the heap_?.c allocator to use from
// 'FreeRTOS-Kernel/portable/MemMang' (Default: heap_4.c)
// b.get_cc().file("More.c"); // Optional additional C-Code to be compiled
b.compile().unwrap_or_else(|e| { panic!("{}", e.to_string()) });
}
```### Used C compiler
`freertos-cargo-build` depends on the [cc crate](https://docs.rs/crate/cc). So the C compiler
used can be set by using the `CC` enviroment variable or otherwise defined by internal
defaults. For the ARM architecture this is the `arm-none-eabi-gcc` which can be found [here](https://developer.arm.com/tools-and-software/open-source-software/developer-tools/gnu-toolchain/gnu-rm/downloads).## Examples
To get started there are examples in [freertos-rust-examples](freertos-rust-examples) for:* Cortex M33 (nRF9160)
* Cortex M3 (STM32L151CBU6A)
* Cortex M4 (STM32F411CEU6)
* Windows
* ...more to come...## Project Crates
* To build a project using this create see [freertos-cargo-build](freertos-cargo-build)
* The runtime dependency for you FreeRTOS Rust application will be [freertos-rust](freertos-rust)# License
This repository is using the MIT License. Some parts might state different licenses that need to be respected when used.* The [Linux port](https://github.com/michaelbecker/freertos-addons) is licensed under GPLv2