2019-04-22 22:21:46 +02:00
|
|
|
//! examples/pool.rs
|
|
|
|
|
|
|
|
#![deny(unsafe_code)]
|
|
|
|
#![deny(warnings)]
|
|
|
|
#![no_main]
|
|
|
|
#![no_std]
|
|
|
|
|
|
|
|
use cortex_m_semihosting::{debug, hprintln};
|
|
|
|
use heapless::{
|
|
|
|
pool,
|
|
|
|
pool::singleton::{Box, Pool},
|
|
|
|
};
|
|
|
|
use lm3s6965::Interrupt;
|
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]);
|
|
|
|
|
|
|
|
#[app(device = lm3s6965)]
|
|
|
|
const APP: () = {
|
|
|
|
#[init]
|
|
|
|
fn init(_: init::Context) {
|
|
|
|
static mut MEMORY: [u8; 512] = [0; 512];
|
|
|
|
|
|
|
|
// Increase the capacity of the memory pool by ~4
|
|
|
|
P::grow(MEMORY);
|
|
|
|
|
2020-06-11 19:18:29 +02:00
|
|
|
rtic::pend(Interrupt::I2C0);
|
2019-04-22 22:21:46 +02:00
|
|
|
}
|
|
|
|
|
2019-06-20 06:19:59 +02:00
|
|
|
#[task(binds = I2C0, priority = 2, spawn = [foo, bar])]
|
|
|
|
fn i2c0(c: i2c0::Context) {
|
2019-04-22 22:21:46 +02:00
|
|
|
// claim a memory block, leave it uninitialized and ..
|
|
|
|
let x = P::alloc().unwrap().freeze();
|
|
|
|
|
|
|
|
// .. send it to the `foo` task
|
|
|
|
c.spawn.foo(x).ok().unwrap();
|
|
|
|
|
|
|
|
// send another block to the task `bar`
|
|
|
|
c.spawn.bar(P::alloc().unwrap().freeze()).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);
|
|
|
|
|
|
|
|
debug::exit(debug::EXIT_SUCCESS);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[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-06-26 23:46:09 +02:00
|
|
|
// RTIC requires that unused interrupts are declared in an extern block when
|
|
|
|
// using software tasks; these free interrupts will be used to dispatch the
|
|
|
|
// software tasks.
|
2019-04-22 22:21:46 +02:00
|
|
|
extern "C" {
|
2020-06-26 23:46:09 +02:00
|
|
|
fn SSI0();
|
|
|
|
fn QEI0();
|
2019-04-22 22:21:46 +02:00
|
|
|
}
|
|
|
|
};
|