aboutsummaryrefslogtreecommitdiff
path: root/examples/stm32f3/src/bin/multiprio.rs
diff options
context:
space:
mode:
authorDario Nieuwenhuis <[email protected]>2023-02-27 01:08:16 +0100
committerDario Nieuwenhuis <[email protected]>2023-02-28 23:07:20 +0100
commit4dfa32b1e0572c03a5f97f0ed4a4a0acd6f12cca (patch)
tree377c51d177d5b4edf235da7fa5099bf42aebaf17 /examples/stm32f3/src/bin/multiprio.rs
parent711ce1014552b715190b1ee6780cafc92fe54240 (diff)
cortex-m/executor: don't use the owned interrupts system.
Preparation for #1224.
Diffstat (limited to 'examples/stm32f3/src/bin/multiprio.rs')
-rw-r--r--examples/stm32f3/src/bin/multiprio.rs36
1 files changed, 23 insertions, 13 deletions
diff --git a/examples/stm32f3/src/bin/multiprio.rs b/examples/stm32f3/src/bin/multiprio.rs
index 9e8228a4b..77df51ac7 100644
--- a/examples/stm32f3/src/bin/multiprio.rs
+++ b/examples/stm32f3/src/bin/multiprio.rs
@@ -57,11 +57,14 @@
57#![no_main] 57#![no_main]
58#![feature(type_alias_impl_trait)] 58#![feature(type_alias_impl_trait)]
59 59
60use core::mem;
61
62use cortex_m::peripheral::NVIC;
60use cortex_m_rt::entry; 63use cortex_m_rt::entry;
61use defmt::*; 64use defmt::*;
62use embassy_stm32::executor::{Executor, InterruptExecutor}; 65use embassy_stm32::executor::{Executor, InterruptExecutor};
63use embassy_stm32::interrupt; 66use embassy_stm32::interrupt;
64use embassy_stm32::interrupt::InterruptExt; 67use embassy_stm32::pac::Interrupt;
65use embassy_time::{Duration, Instant, Timer}; 68use embassy_time::{Duration, Instant, Timer};
66use static_cell::StaticCell; 69use static_cell::StaticCell;
67use {defmt_rtt as _, panic_probe as _}; 70use {defmt_rtt as _, panic_probe as _};
@@ -108,28 +111,35 @@ async fn run_low() {
108 } 111 }
109} 112}
110 113
111static EXECUTOR_HIGH: StaticCell<InterruptExecutor<interrupt::UART4>> = StaticCell::new(); 114static EXECUTOR_HIGH: InterruptExecutor = InterruptExecutor::new();
112static EXECUTOR_MED: StaticCell<InterruptExecutor<interrupt::UART5>> = StaticCell::new(); 115static EXECUTOR_MED: InterruptExecutor = InterruptExecutor::new();
113static EXECUTOR_LOW: StaticCell<Executor> = StaticCell::new(); 116static EXECUTOR_LOW: StaticCell<Executor> = StaticCell::new();
114 117
118#[interrupt]
119unsafe fn UART4() {
120 EXECUTOR_HIGH.on_interrupt()
121}
122
123#[interrupt]
124unsafe fn UART5() {
125 EXECUTOR_MED.on_interrupt()
126}
127
115#[entry] 128#[entry]
116fn main() -> ! { 129fn main() -> ! {
117 info!("Hello World!"); 130 info!("Hello World!");
118 131
119 let _p = embassy_stm32::init(Default::default()); 132 let _p = embassy_stm32::init(Default::default());
133 let mut nvic: NVIC = unsafe { mem::transmute(()) };
120 134
121 // High-priority executor: SWI1_EGU1, priority level 6 135 // High-priority executor: UART4, priority level 6
122 let irq = interrupt::take!(UART4); 136 unsafe { nvic.set_priority(Interrupt::UART4, 6 << 4) };
123 irq.set_priority(interrupt::Priority::P6); 137 let spawner = EXECUTOR_HIGH.start(Interrupt::UART4);
124 let executor = EXECUTOR_HIGH.init(InterruptExecutor::new(irq));
125 let spawner = executor.start();
126 unwrap!(spawner.spawn(run_high())); 138 unwrap!(spawner.spawn(run_high()));
127 139
128 // Medium-priority executor: SWI0_EGU0, priority level 7 140 // Medium-priority executor: UART5, priority level 7
129 let irq = interrupt::take!(UART5); 141 unsafe { nvic.set_priority(Interrupt::UART5, 7 << 4) };
130 irq.set_priority(interrupt::Priority::P7); 142 let spawner = EXECUTOR_MED.start(Interrupt::UART5);
131 let executor = EXECUTOR_MED.init(InterruptExecutor::new(irq));
132 let spawner = executor.start();
133 unwrap!(spawner.spawn(run_med())); 143 unwrap!(spawner.spawn(run_med()));
134 144
135 // Low priority executor: runs in thread mode, using WFE/SEV 145 // Low priority executor: runs in thread mode, using WFE/SEV