mirror of
https://github.com/rtic-rs/rtic.git
synced 2024-11-26 05:29:38 +01:00
53ed7bf7ed
* fix included examples and markdown(book) fixes: #911 * fix footnote pre_init * more example link updates * Restore pool example name * Example: pool: Upgrade to heapless v0.8 * Example: pool: thumbv6 unsupported: wild cfg-if Experiment with multi-backend example contained in the example * Example: lm3s6965: Updated cargo.lock * Book: Use cargo xtask for by-example * Docs: Contributing: cargo xtask --------- Co-authored-by: Henrik Tjäder <henrik@tjaders.com>
102 lines
2.9 KiB
Rust
102 lines
2.9 KiB
Rust
//! examples/pool.rs
|
|
|
|
#![no_main]
|
|
#![no_std]
|
|
#![deny(warnings)]
|
|
|
|
use panic_semihosting as _;
|
|
use rtic::app;
|
|
|
|
// thumbv6-none-eabi does not support pool
|
|
// This might be better worked around in the build system,
|
|
// but for proof of concept, let's try having one example
|
|
// being different for different backends
|
|
// https://docs.rs/heapless/0.8.0/heapless/pool/index.html#target-support
|
|
cfg_if::cfg_if! {
|
|
if #[cfg(feature = "thumbv6-backend")] {
|
|
// Copy of the smallest.rs example
|
|
#[app(device = lm3s6965)]
|
|
mod app {
|
|
use cortex_m_semihosting::debug;
|
|
|
|
#[shared]
|
|
struct Shared {}
|
|
|
|
#[local]
|
|
struct Local {}
|
|
|
|
#[init]
|
|
fn init(_: init::Context) -> (Shared, Local) {
|
|
debug::exit(debug::EXIT_SUCCESS); // Exit QEMU simulator
|
|
(Shared {}, Local {})
|
|
}
|
|
}
|
|
} else {
|
|
// Run actual pool example
|
|
use heapless::{
|
|
box_pool,
|
|
pool::boxed::{Box, BoxBlock},
|
|
};
|
|
|
|
// Declare a pool containing 8-byte memory blocks
|
|
box_pool!(P: u8);
|
|
|
|
const POOL_CAPACITY: usize = 512;
|
|
|
|
#[app(device = lm3s6965, dispatchers = [SSI0, QEI0])]
|
|
mod app {
|
|
use crate::{Box, BoxBlock, POOL_CAPACITY};
|
|
use cortex_m_semihosting::debug;
|
|
use lm3s6965::Interrupt;
|
|
|
|
// Import the memory pool into scope
|
|
use crate::P;
|
|
|
|
#[shared]
|
|
struct Shared {}
|
|
|
|
#[local]
|
|
struct Local {}
|
|
|
|
const BLOCK: BoxBlock<u8> = BoxBlock::new();
|
|
|
|
#[init(local = [memory: [BoxBlock<u8>; POOL_CAPACITY] = [BLOCK; POOL_CAPACITY]])]
|
|
fn init(cx: init::Context) -> (Shared, Local) {
|
|
for block in cx.local.memory {
|
|
// Give the 'static memory to the pool
|
|
P.manage(block);
|
|
}
|
|
|
|
rtic::pend(Interrupt::I2C0);
|
|
|
|
(Shared {}, Local {})
|
|
}
|
|
|
|
#[task(binds = I2C0, priority = 2)]
|
|
fn i2c0(_: i2c0::Context) {
|
|
// Claim 128 u8 blocks
|
|
let x = P.alloc(128).unwrap();
|
|
|
|
// .. send it to the `foo` task
|
|
foo::spawn(x).ok().unwrap();
|
|
|
|
// send another 128 u8 blocks to the task `bar`
|
|
bar::spawn(P.alloc(128).unwrap()).ok().unwrap();
|
|
}
|
|
|
|
#[task]
|
|
async fn foo(_: foo::Context, _x: Box<P>) {
|
|
// explicitly return the block to the pool
|
|
drop(_x);
|
|
|
|
debug::exit(debug::EXIT_SUCCESS); // Exit QEMU simulator
|
|
}
|
|
|
|
#[task(priority = 2)]
|
|
async fn bar(_: bar::Context, _x: Box<P>) {
|
|
// this is done automatically so we can omit the call to `drop`
|
|
// drop(_x);
|
|
}
|
|
}
|
|
}
|
|
}
|