mirror of
https://github.com/rtic-rs/rtic.git
synced 2025-12-18 13:55:23 +01:00
* Rebase to master * using interrupt_mod * bug fixes * fix other backends * Add changelog * forgot about rtic-macros * backend-specific configuration * core peripherals optional over macro argument * pre_init_preprocessing binding * CI for RISC-V (WIP) * separation of concerns * add targets for RISC-V examples * remove qemu feature * prepare examples folder * move examples all together * move ci out of examples * minor changes * add cortex-m * new xtask: proof of concept * fix build.yml * feature typo * clean rtic examples * reproduce weird issue * remove unsafe code in user app * update dependencies * allow builds on riscv32imc * let's fix QEMU * Update .github/workflows/build.yml Co-authored-by: Henrik Tjäder <henrik@tjaders.com> * New build.rs * removing test features * adapt ui test to new version of clippy * add more examples to RISC-V backend * proper configuration of heapless for riscv32imc * opt-out examples for riscv32imc * point to new version of riscv-slic * adapt new macro bindings * adapt examples and CI to stable * fix cortex-m CI * Review --------- Co-authored-by: Henrik Tjäder <henrik@tjaders.com>
69 lines
1.6 KiB
Text
69 lines
1.6 KiB
Text
//! examples/pool.rs
|
|
|
|
#![no_main]
|
|
#![no_std]
|
|
#![deny(warnings)]
|
|
|
|
use heapless::{
|
|
pool,
|
|
pool::singleton::{Box, Pool},
|
|
};
|
|
use panic_semihosting as _;
|
|
use rtic::app;
|
|
|
|
// Declare a pool of 128-byte memory blocks
|
|
pool!(P: [u8; 128]);
|
|
|
|
#[app(device = lm3s6965, dispatchers = [SSI0, QEI0])]
|
|
mod app {
|
|
use crate::{Box, Pool};
|
|
use cortex_m_semihosting::debug;
|
|
use lm3s6965::Interrupt;
|
|
|
|
// Import the memory pool into scope
|
|
use super::P;
|
|
|
|
#[shared]
|
|
struct Shared {}
|
|
|
|
#[local]
|
|
struct Local {}
|
|
|
|
#[init(local = [memory: [u8; 512] = [0; 512]])]
|
|
fn init(cx: init::Context) -> (Shared, Local) {
|
|
// Increase the capacity of the memory pool by ~4
|
|
P::grow(cx.local.memory);
|
|
|
|
rtic::pend(Interrupt::I2C0);
|
|
|
|
(Shared {}, Local {})
|
|
}
|
|
|
|
#[task(binds = I2C0, priority = 2)]
|
|
fn i2c0(_: i2c0::Context) {
|
|
// 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`
|
|
bar::spawn(P::alloc().unwrap().init([0u8; 128]))
|
|
.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);
|
|
}
|
|
}
|