aboutsummaryrefslogtreecommitdiff
path: root/examples/nrf52840/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/nrf52840/src/bin/multiprio.rs
parent711ce1014552b715190b1ee6780cafc92fe54240 (diff)
cortex-m/executor: don't use the owned interrupts system.
Preparation for #1224.
Diffstat (limited to 'examples/nrf52840/src/bin/multiprio.rs')
-rw-r--r--examples/nrf52840/src/bin/multiprio.rs32
1 files changed, 21 insertions, 11 deletions
diff --git a/examples/nrf52840/src/bin/multiprio.rs b/examples/nrf52840/src/bin/multiprio.rs
index 25806ae48..851e189ea 100644
--- a/examples/nrf52840/src/bin/multiprio.rs
+++ b/examples/nrf52840/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::{info, unwrap}; 64use defmt::{info, unwrap};
62use embassy_nrf::executor::{Executor, InterruptExecutor}; 65use embassy_nrf::executor::{Executor, InterruptExecutor};
63use embassy_nrf::interrupt; 66use embassy_nrf::interrupt;
64use embassy_nrf::interrupt::InterruptExt; 67use embassy_nrf::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::SWI1_EGU1>> = StaticCell::new(); 114static EXECUTOR_HIGH: InterruptExecutor = InterruptExecutor::new();
112static EXECUTOR_MED: StaticCell<InterruptExecutor<interrupt::SWI0_EGU0>> = 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 SWI1_EGU1() {
120 EXECUTOR_HIGH.on_interrupt()
121}
122
123#[interrupt]
124unsafe fn SWI0_EGU0() {
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_nrf::init(Default::default()); 132 let _p = embassy_nrf::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: SWI1_EGU1, priority level 6
122 let irq = interrupt::take!(SWI1_EGU1); 136 unsafe { nvic.set_priority(Interrupt::SWI1_EGU1, 6 << 5) };
123 irq.set_priority(interrupt::Priority::P6); 137 let spawner = EXECUTOR_HIGH.start(Interrupt::SWI1_EGU1);
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: SWI0_EGU0, priority level 7
129 let irq = interrupt::take!(SWI0_EGU0); 141 unsafe { nvic.set_priority(Interrupt::SWI0_EGU0, 7 << 5) };
130 irq.set_priority(interrupt::Priority::P7); 142 let spawner = EXECUTOR_MED.start(Interrupt::SWI0_EGU0);
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