aboutsummaryrefslogtreecommitdiff
path: root/examples
diff options
context:
space:
mode:
authorbors[bot] <26634292+bors[bot]@users.noreply.github.com>2022-04-25 20:21:32 +0000
committerGitHub <[email protected]>2022-04-25 20:21:32 +0000
commita39d796c3de9c96ea4df6b9da525cb0d5ef60fc0 (patch)
tree77db234bb173a5da49e1815e82f3dd29402db79d /examples
parent97e24b056879547bb21158c2193f67ddb9e0a790 (diff)
parent2b0e8a330b0f2be7a8943a9e5acadf8fc7f92275 (diff)
Merge #730
730: Executor and task macro fixes. r=Dirbaio a=Dirbaio See individual commits. bors r+ Co-authored-by: Dario Nieuwenhuis <[email protected]>
Diffstat (limited to 'examples')
-rw-r--r--examples/nrf/src/bin/multiprio.rs10
-rw-r--r--examples/nrf/src/bin/self_spawn.rs24
-rw-r--r--examples/stm32f3/src/bin/multiprio.rs10
-rw-r--r--examples/stm32f4/src/bin/multiprio.rs10
4 files changed, 36 insertions, 18 deletions
diff --git a/examples/nrf/src/bin/multiprio.rs b/examples/nrf/src/bin/multiprio.rs
index e69f87d85..54f6606a9 100644
--- a/examples/nrf/src/bin/multiprio.rs
+++ b/examples/nrf/src/bin/multiprio.rs
@@ -124,17 +124,15 @@ fn main() -> ! {
124 let irq = interrupt::take!(SWI1_EGU1); 124 let irq = interrupt::take!(SWI1_EGU1);
125 irq.set_priority(interrupt::Priority::P6); 125 irq.set_priority(interrupt::Priority::P6);
126 let executor = EXECUTOR_HIGH.put(InterruptExecutor::new(irq)); 126 let executor = EXECUTOR_HIGH.put(InterruptExecutor::new(irq));
127 executor.start(|spawner| { 127 let spawner = executor.start();
128 unwrap!(spawner.spawn(run_high())); 128 unwrap!(spawner.spawn(run_high()));
129 });
130 129
131 // Medium-priority executor: SWI0_EGU0, priority level 7 130 // Medium-priority executor: SWI0_EGU0, priority level 7
132 let irq = interrupt::take!(SWI0_EGU0); 131 let irq = interrupt::take!(SWI0_EGU0);
133 irq.set_priority(interrupt::Priority::P7); 132 irq.set_priority(interrupt::Priority::P7);
134 let executor = EXECUTOR_MED.put(InterruptExecutor::new(irq)); 133 let executor = EXECUTOR_MED.put(InterruptExecutor::new(irq));
135 executor.start(|spawner| { 134 let spawner = executor.start();
136 unwrap!(spawner.spawn(run_med())); 135 unwrap!(spawner.spawn(run_med()));
137 });
138 136
139 // Low priority executor: runs in thread mode, using WFE/SEV 137 // Low priority executor: runs in thread mode, using WFE/SEV
140 let executor = EXECUTOR_LOW.put(Executor::new()); 138 let executor = EXECUTOR_LOW.put(Executor::new());
diff --git a/examples/nrf/src/bin/self_spawn.rs b/examples/nrf/src/bin/self_spawn.rs
new file mode 100644
index 000000000..35e73a8dd
--- /dev/null
+++ b/examples/nrf/src/bin/self_spawn.rs
@@ -0,0 +1,24 @@
1#![no_std]
2#![no_main]
3#![feature(type_alias_impl_trait)]
4
5use defmt::{info, unwrap};
6use embassy::executor::Spawner;
7use embassy::time::{Duration, Timer};
8use embassy_nrf::Peripherals;
9
10use defmt_rtt as _; // global logger
11use panic_probe as _;
12
13#[embassy::task(pool_size = 2)]
14async fn my_task(spawner: Spawner, n: u32) {
15 Timer::after(Duration::from_secs(1)).await;
16 info!("Spawning self! {}", n);
17 unwrap!(spawner.spawn(my_task(spawner, n + 1)));
18}
19
20#[embassy::main]
21async fn main(spawner: Spawner, _p: Peripherals) {
22 info!("Hello World!");
23 unwrap!(spawner.spawn(my_task(spawner, 0)));
24}
diff --git a/examples/stm32f3/src/bin/multiprio.rs b/examples/stm32f3/src/bin/multiprio.rs
index 1c9401549..02380de72 100644
--- a/examples/stm32f3/src/bin/multiprio.rs
+++ b/examples/stm32f3/src/bin/multiprio.rs
@@ -124,17 +124,15 @@ fn main() -> ! {
124 let irq = interrupt::take!(UART4); 124 let irq = interrupt::take!(UART4);
125 irq.set_priority(interrupt::Priority::P6); 125 irq.set_priority(interrupt::Priority::P6);
126 let executor = EXECUTOR_HIGH.put(InterruptExecutor::new(irq)); 126 let executor = EXECUTOR_HIGH.put(InterruptExecutor::new(irq));
127 executor.start(|spawner| { 127 let spawner = executor.start();
128 unwrap!(spawner.spawn(run_high())); 128 unwrap!(spawner.spawn(run_high()));
129 });
130 129
131 // Medium-priority executor: SWI0_EGU0, priority level 7 130 // Medium-priority executor: SWI0_EGU0, priority level 7
132 let irq = interrupt::take!(UART5); 131 let irq = interrupt::take!(UART5);
133 irq.set_priority(interrupt::Priority::P7); 132 irq.set_priority(interrupt::Priority::P7);
134 let executor = EXECUTOR_MED.put(InterruptExecutor::new(irq)); 133 let executor = EXECUTOR_MED.put(InterruptExecutor::new(irq));
135 executor.start(|spawner| { 134 let spawner = executor.start();
136 unwrap!(spawner.spawn(run_med())); 135 unwrap!(spawner.spawn(run_med()));
137 });
138 136
139 // Low priority executor: runs in thread mode, using WFE/SEV 137 // Low priority executor: runs in thread mode, using WFE/SEV
140 let executor = EXECUTOR_LOW.put(Executor::new()); 138 let executor = EXECUTOR_LOW.put(Executor::new());
diff --git a/examples/stm32f4/src/bin/multiprio.rs b/examples/stm32f4/src/bin/multiprio.rs
index 1c9401549..02380de72 100644
--- a/examples/stm32f4/src/bin/multiprio.rs
+++ b/examples/stm32f4/src/bin/multiprio.rs
@@ -124,17 +124,15 @@ fn main() -> ! {
124 let irq = interrupt::take!(UART4); 124 let irq = interrupt::take!(UART4);
125 irq.set_priority(interrupt::Priority::P6); 125 irq.set_priority(interrupt::Priority::P6);
126 let executor = EXECUTOR_HIGH.put(InterruptExecutor::new(irq)); 126 let executor = EXECUTOR_HIGH.put(InterruptExecutor::new(irq));
127 executor.start(|spawner| { 127 let spawner = executor.start();
128 unwrap!(spawner.spawn(run_high())); 128 unwrap!(spawner.spawn(run_high()));
129 });
130 129
131 // Medium-priority executor: SWI0_EGU0, priority level 7 130 // Medium-priority executor: SWI0_EGU0, priority level 7
132 let irq = interrupt::take!(UART5); 131 let irq = interrupt::take!(UART5);
133 irq.set_priority(interrupt::Priority::P7); 132 irq.set_priority(interrupt::Priority::P7);
134 let executor = EXECUTOR_MED.put(InterruptExecutor::new(irq)); 133 let executor = EXECUTOR_MED.put(InterruptExecutor::new(irq));
135 executor.start(|spawner| { 134 let spawner = executor.start();
136 unwrap!(spawner.spawn(run_med())); 135 unwrap!(spawner.spawn(run_med()));
137 });
138 136
139 // Low priority executor: runs in thread mode, using WFE/SEV 137 // Low priority executor: runs in thread mode, using WFE/SEV
140 let executor = EXECUTOR_LOW.put(Executor::new()); 138 let executor = EXECUTOR_LOW.put(Executor::new());