2019-04-22 22:21:46 +02:00
|
|
|
//! examples/pool.rs
|
|
|
|
|
|
|
|
#![deny(unsafe_code)]
|
|
|
|
#![deny(warnings)]
|
2023-01-22 00:22:46 +01:00
|
|
|
// pool!() generates a struct without docs
|
|
|
|
//#![deny(missing_docs)]
|
2019-04-22 22:21:46 +02:00
|
|
|
#![no_main]
|
|
|
|
#![no_std]
|
|
|
|
|
|
|
|
use heapless::{
|
|
|
|
pool,
|
|
|
|
pool::singleton::{Box, Pool},
|
|
|
|
};
|
2019-06-13 23:56:59 +02:00
|
|
|
use panic_semihosting as _;
|
2020-06-11 19:18:29 +02:00
|
|
|
use rtic::app;
|
2019-04-22 22:21:46 +02:00
|
|
|
|
|
|
|
// 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;
|
2020-06-08 09:42:19 +02:00
|
|
|
|
|
|
|
// 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 {}
|
2019-04-22 22:21:46 +02:00
|
|
|
|
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) {
|
2019-04-22 22:21:46 +02:00
|
|
|
// Increase the capacity of the memory pool by ~4
|
2021-07-07 22:50:59 +02:00
|
|
|
P::grow(cx.local.memory);
|
2019-04-22 22:21:46 +02:00
|
|
|
|
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())
|
2019-04-22 22:21:46 +02:00
|
|
|
}
|
|
|
|
|
2020-10-11 19:41:57 +02:00
|
|
|
#[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]);
|
2019-04-22 22:21:46 +02:00
|
|
|
|
|
|
|
// .. send it to the `foo` task
|
2020-10-11 19:41:57 +02:00
|
|
|
foo::spawn(x).ok().unwrap();
|
2019-04-22 22:21:46 +02:00
|
|
|
|
|
|
|
// 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();
|
2019-04-22 22:21:46 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[task]
|
|
|
|
fn foo(_: foo::Context, x: Box<P>) {
|
2023-01-11 21:33:44 +01:00
|
|
|
hprintln!("foo({:?})", x.as_ptr());
|
2019-04-22 22:21:46 +02:00
|
|
|
|
|
|
|
// 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
|
2019-04-22 22:21:46 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[task(priority = 2)]
|
|
|
|
fn bar(_: bar::Context, x: Box<P>) {
|
2023-01-11 21:33:44 +01:00
|
|
|
hprintln!("bar({:?})", x.as_ptr());
|
2019-04-22 22:21:46 +02:00
|
|
|
|
|
|
|
// this is done automatically so we can omit the call to `drop`
|
|
|
|
// drop(x);
|
|
|
|
}
|
2020-04-22 12:58:14 +02:00
|
|
|
}
|