rtic/examples/pool.rs

75 lines
1.7 KiB
Rust
Raw Normal View History

//! examples/pool.rs
#![deny(unsafe_code)]
#![deny(warnings)]
#![no_main]
#![no_std]
use heapless::{
pool,
pool::singleton::{Box, Pool},
};
use panic_semihosting as _;
2020-06-11 19:18:29 +02:00
use rtic::app;
// Declare a pool of 128-byte memory blocks
pool!(P: [u8; 128]);
2020-10-23 10:35:56 +02:00
#[app(device = lm3s6965, dispatchers = [SSI0, QEI0])]
2020-05-19 20:00:13 +02:00
mod app {
2020-10-15 18:50:17 +02:00
use crate::{Box, Pool};
use cortex_m_semihosting::{debug, hprintln};
use lm3s6965::Interrupt;
// Import the memory pool into scope
use super::P;
2020-05-19 20:00:13 +02:00
2021-07-07 22:50:59 +02:00
#[shared]
struct Shared {}
2021-07-07 22:50:59 +02:00
#[local]
struct Local {}
#[init(local = [memory: [u8; 512] = [0; 512]])]
fn init(cx: init::Context) -> (Shared, Local, init::Monotonics) {
// Increase the capacity of the memory pool by ~4
2021-07-07 22:50:59 +02:00
P::grow(cx.local.memory);
2020-06-11 19:18:29 +02:00
rtic::pend(Interrupt::I2C0);
2020-10-01 19:38:49 +02:00
2021-07-07 22:50:59 +02:00
(Shared {}, Local {}, init::Monotonics())
}
#[task(binds = I2C0, priority = 2)]
fn i2c0(_: i2c0::Context) {
2021-07-20 10:13:24 +02:00
// claim a memory block, initialize it and ..
let x = P::alloc().unwrap().init([0u8; 128]);
// .. send it to the `foo` task
foo::spawn(x).ok().unwrap();
// send another block to the task `bar`
2021-07-20 10:44:03 +02:00
bar::spawn(P::alloc().unwrap().init([0u8; 128]))
.ok()
.unwrap();
}
#[task]
fn foo(_: foo::Context, x: Box<P>) {
hprintln!("foo({:?})", x.as_ptr()).unwrap();
// explicitly return the block to the pool
drop(x);
2021-09-22 13:22:45 +02:00
debug::exit(debug::EXIT_SUCCESS); // Exit QEMU simulator
}
#[task(priority = 2)]
fn bar(_: bar::Context, x: Box<P>) {
hprintln!("bar({:?})", x.as_ptr()).unwrap();
// this is done automatically so we can omit the call to `drop`
// drop(x);
}
2020-04-22 12:58:14 +02:00
}