diff options
| author | Dario Nieuwenhuis <[email protected]> | 2021-05-17 01:04:13 +0200 |
|---|---|---|
| committer | GitHub <[email protected]> | 2021-05-17 01:04:13 +0200 |
| commit | 35d05a4214e035bbb6da380c38c0a90b285887f2 (patch) | |
| tree | de9f18e1f858e62b03c0c465135bea3f57d926ac /embassy-nrf-examples/src | |
| parent | cd4111736c0384b1ef957df7f6aa51e3727c29b2 (diff) | |
| parent | a5ad79927ecaa9d6cd7bd96e015b66afa9201d84 (diff) | |
Merge pull request #174 from embassy-rs/nrf-neo
nRF-neo
Diffstat (limited to 'embassy-nrf-examples/src')
| -rw-r--r-- | embassy-nrf-examples/src/bin/blinky.rs | 3 | ||||
| -rw-r--r-- | embassy-nrf-examples/src/bin/buffered_uart.rs | 4 | ||||
| -rw-r--r-- | embassy-nrf-examples/src/bin/executor_fairness_test.rs | 4 | ||||
| -rw-r--r-- | embassy-nrf-examples/src/bin/gpiote_channel.rs | 11 | ||||
| -rw-r--r-- | embassy-nrf-examples/src/bin/gpiote_port.rs | 17 | ||||
| -rw-r--r-- | embassy-nrf-examples/src/bin/multiprio.rs | 3 | ||||
| -rw-r--r-- | embassy-nrf-examples/src/bin/ppi.rs | 11 | ||||
| -rw-r--r-- | embassy-nrf-examples/src/bin/pwm.rs | 104 | ||||
| -rw-r--r-- | embassy-nrf-examples/src/bin/qspi.rs | 4 | ||||
| -rw-r--r-- | embassy-nrf-examples/src/bin/raw_spawn.rs | 3 | ||||
| -rw-r--r-- | embassy-nrf-examples/src/bin/spim.rs | 13 | ||||
| -rw-r--r-- | embassy-nrf-examples/src/bin/timer.rs | 3 | ||||
| -rw-r--r-- | embassy-nrf-examples/src/bin/uart.rs | 32 | ||||
| -rw-r--r-- | embassy-nrf-examples/src/bin/uart_idle.rs | 4 |
14 files changed, 129 insertions, 87 deletions
diff --git a/embassy-nrf-examples/src/bin/blinky.rs b/embassy-nrf-examples/src/bin/blinky.rs index 4cb09bee7..e6fc854b5 100644 --- a/embassy-nrf-examples/src/bin/blinky.rs +++ b/embassy-nrf-examples/src/bin/blinky.rs | |||
| @@ -17,8 +17,7 @@ use embassy_nrf::Peripherals; | |||
| 17 | use embedded_hal::digital::v2::OutputPin; | 17 | use embedded_hal::digital::v2::OutputPin; |
| 18 | 18 | ||
| 19 | #[embassy::main] | 19 | #[embassy::main] |
| 20 | async fn main(spawner: Spawner) { | 20 | async fn main(spawner: Spawner, p: Peripherals) { |
| 21 | let p = Peripherals::take().unwrap(); | ||
| 22 | let mut led = Output::new(p.P0_13, Level::Low, OutputDrive::Standard); | 21 | let mut led = Output::new(p.P0_13, Level::Low, OutputDrive::Standard); |
| 23 | 22 | ||
| 24 | loop { | 23 | loop { |
diff --git a/embassy-nrf-examples/src/bin/buffered_uart.rs b/embassy-nrf-examples/src/bin/buffered_uart.rs index 8f5d9fb2e..b3a621c6b 100644 --- a/embassy-nrf-examples/src/bin/buffered_uart.rs +++ b/embassy-nrf-examples/src/bin/buffered_uart.rs | |||
| @@ -17,9 +17,7 @@ use example_common::*; | |||
| 17 | use futures::pin_mut; | 17 | use futures::pin_mut; |
| 18 | 18 | ||
| 19 | #[embassy::main] | 19 | #[embassy::main] |
| 20 | async fn main(spawner: Spawner) { | 20 | async fn main(spawner: Spawner, p: Peripherals) { |
| 21 | let p = Peripherals::take().unwrap(); | ||
| 22 | |||
| 23 | let mut config = uarte::Config::default(); | 21 | let mut config = uarte::Config::default(); |
| 24 | config.parity = uarte::Parity::EXCLUDED; | 22 | config.parity = uarte::Parity::EXCLUDED; |
| 25 | config.baudrate = uarte::Baudrate::BAUD115200; | 23 | config.baudrate = uarte::Baudrate::BAUD115200; |
diff --git a/embassy-nrf-examples/src/bin/executor_fairness_test.rs b/embassy-nrf-examples/src/bin/executor_fairness_test.rs index 3ea74316e..ca9bcc1e6 100644 --- a/embassy-nrf-examples/src/bin/executor_fairness_test.rs +++ b/embassy-nrf-examples/src/bin/executor_fairness_test.rs | |||
| @@ -13,7 +13,7 @@ use core::task::Poll; | |||
| 13 | use defmt::panic; | 13 | use defmt::panic; |
| 14 | use embassy::executor::Spawner; | 14 | use embassy::executor::Spawner; |
| 15 | use embassy::time::{Duration, Instant, Timer}; | 15 | use embassy::time::{Duration, Instant, Timer}; |
| 16 | use embassy_nrf::interrupt; | 16 | use embassy_nrf::{interrupt, Peripherals}; |
| 17 | 17 | ||
| 18 | #[embassy::task] | 18 | #[embassy::task] |
| 19 | async fn run1() { | 19 | async fn run1() { |
| @@ -40,7 +40,7 @@ async fn run3() { | |||
| 40 | } | 40 | } |
| 41 | 41 | ||
| 42 | #[embassy::main] | 42 | #[embassy::main] |
| 43 | async fn main(spawner: Spawner) { | 43 | async fn main(spawner: Spawner, p: Peripherals) { |
| 44 | unwrap!(spawner.spawn(run1())); | 44 | unwrap!(spawner.spawn(run1())); |
| 45 | unwrap!(spawner.spawn(run2())); | 45 | unwrap!(spawner.spawn(run2())); |
| 46 | unwrap!(spawner.spawn(run3())); | 46 | unwrap!(spawner.spawn(run3())); |
diff --git a/embassy-nrf-examples/src/bin/gpiote_channel.rs b/embassy-nrf-examples/src/bin/gpiote_channel.rs index 9e653192b..d52ed7767 100644 --- a/embassy-nrf-examples/src/bin/gpiote_channel.rs +++ b/embassy-nrf-examples/src/bin/gpiote_channel.rs | |||
| @@ -12,36 +12,29 @@ use example_common::*; | |||
| 12 | use defmt::panic; | 12 | use defmt::panic; |
| 13 | use embassy::executor::Spawner; | 13 | use embassy::executor::Spawner; |
| 14 | use embassy_nrf::gpio::{Input, Pull}; | 14 | use embassy_nrf::gpio::{Input, Pull}; |
| 15 | use embassy_nrf::gpiote::{self, InputChannel, InputChannelPolarity}; | 15 | use embassy_nrf::gpiote::{InputChannel, InputChannelPolarity}; |
| 16 | use embassy_nrf::{interrupt, Peripherals}; | 16 | use embassy_nrf::{interrupt, Peripherals}; |
| 17 | 17 | ||
| 18 | #[embassy::main] | 18 | #[embassy::main] |
| 19 | async fn main(spawner: Spawner) { | 19 | async fn main(spawner: Spawner, p: Peripherals) { |
| 20 | let p = Peripherals::take().unwrap(); | ||
| 21 | let g = gpiote::initialize(p.GPIOTE, interrupt::take!(GPIOTE)); | ||
| 22 | |||
| 23 | info!("Starting!"); | 20 | info!("Starting!"); |
| 24 | 21 | ||
| 25 | let ch1 = InputChannel::new( | 22 | let ch1 = InputChannel::new( |
| 26 | g, | ||
| 27 | p.GPIOTE_CH0, | 23 | p.GPIOTE_CH0, |
| 28 | Input::new(p.P0_11, Pull::Up), | 24 | Input::new(p.P0_11, Pull::Up), |
| 29 | InputChannelPolarity::HiToLo, | 25 | InputChannelPolarity::HiToLo, |
| 30 | ); | 26 | ); |
| 31 | let ch2 = InputChannel::new( | 27 | let ch2 = InputChannel::new( |
| 32 | g, | ||
| 33 | p.GPIOTE_CH1, | 28 | p.GPIOTE_CH1, |
| 34 | Input::new(p.P0_12, Pull::Up), | 29 | Input::new(p.P0_12, Pull::Up), |
| 35 | InputChannelPolarity::LoToHi, | 30 | InputChannelPolarity::LoToHi, |
| 36 | ); | 31 | ); |
| 37 | let ch3 = InputChannel::new( | 32 | let ch3 = InputChannel::new( |
| 38 | g, | ||
| 39 | p.GPIOTE_CH2, | 33 | p.GPIOTE_CH2, |
| 40 | Input::new(p.P0_24, Pull::Up), | 34 | Input::new(p.P0_24, Pull::Up), |
| 41 | InputChannelPolarity::Toggle, | 35 | InputChannelPolarity::Toggle, |
| 42 | ); | 36 | ); |
| 43 | let ch4 = InputChannel::new( | 37 | let ch4 = InputChannel::new( |
| 44 | g, | ||
| 45 | p.GPIOTE_CH3, | 38 | p.GPIOTE_CH3, |
| 46 | Input::new(p.P0_25, Pull::Up), | 39 | Input::new(p.P0_25, Pull::Up), |
| 47 | InputChannelPolarity::Toggle, | 40 | InputChannelPolarity::Toggle, |
diff --git a/embassy-nrf-examples/src/bin/gpiote_port.rs b/embassy-nrf-examples/src/bin/gpiote_port.rs index 386806dfc..4a7951cd3 100644 --- a/embassy-nrf-examples/src/bin/gpiote_port.rs +++ b/embassy-nrf-examples/src/bin/gpiote_port.rs | |||
| @@ -8,12 +8,11 @@ | |||
| 8 | #[path = "../example_common.rs"] | 8 | #[path = "../example_common.rs"] |
| 9 | mod example_common; | 9 | mod example_common; |
| 10 | 10 | ||
| 11 | use core::pin::Pin; | ||
| 12 | use defmt::panic; | 11 | use defmt::panic; |
| 13 | use embassy::executor::Spawner; | 12 | use embassy::executor::Spawner; |
| 14 | use embassy::traits::gpio::{WaitForHigh, WaitForLow}; | 13 | use embassy::traits::gpio::{WaitForHigh, WaitForLow}; |
| 15 | use embassy_nrf::gpio::{AnyPin, Input, Pin as _, Pull}; | 14 | use embassy_nrf::gpio::{AnyPin, Input, Pin as _, Pull}; |
| 16 | use embassy_nrf::gpiote::{self, PortInput}; | 15 | use embassy_nrf::gpiote::PortInput; |
| 17 | use embassy_nrf::interrupt; | 16 | use embassy_nrf::interrupt; |
| 18 | use embassy_nrf::Peripherals; | 17 | use embassy_nrf::Peripherals; |
| 19 | use example_common::*; | 18 | use example_common::*; |
| @@ -29,15 +28,13 @@ async fn button_task(n: usize, mut pin: PortInput<'static, AnyPin>) { | |||
| 29 | } | 28 | } |
| 30 | 29 | ||
| 31 | #[embassy::main] | 30 | #[embassy::main] |
| 32 | async fn main(spawner: Spawner) { | 31 | async fn main(spawner: Spawner, p: Peripherals) { |
| 33 | let p = Peripherals::take().unwrap(); | 32 | info!("Starting!"); |
| 34 | 33 | ||
| 35 | let g = gpiote::initialize(p.GPIOTE, interrupt::take!(GPIOTE)); | 34 | let btn1 = PortInput::new(Input::new(p.P0_11.degrade(), Pull::Up)); |
| 36 | 35 | let btn2 = PortInput::new(Input::new(p.P0_12.degrade(), Pull::Up)); | |
| 37 | let btn1 = PortInput::new(g, Input::new(p.P0_11.degrade(), Pull::Up)); | 36 | let btn3 = PortInput::new(Input::new(p.P0_24.degrade(), Pull::Up)); |
| 38 | let btn2 = PortInput::new(g, Input::new(p.P0_12.degrade(), Pull::Up)); | 37 | let btn4 = PortInput::new(Input::new(p.P0_25.degrade(), Pull::Up)); |
| 39 | let btn3 = PortInput::new(g, Input::new(p.P0_24.degrade(), Pull::Up)); | ||
| 40 | let btn4 = PortInput::new(g, Input::new(p.P0_25.degrade(), Pull::Up)); | ||
| 41 | 38 | ||
| 42 | spawner.spawn(button_task(1, btn1)).unwrap(); | 39 | spawner.spawn(button_task(1, btn1)).unwrap(); |
| 43 | spawner.spawn(button_task(2, btn2)).unwrap(); | 40 | spawner.spawn(button_task(2, btn2)).unwrap(); |
diff --git a/embassy-nrf-examples/src/bin/multiprio.rs b/embassy-nrf-examples/src/bin/multiprio.rs index 9ed5c1368..79fa029b3 100644 --- a/embassy-nrf-examples/src/bin/multiprio.rs +++ b/embassy-nrf-examples/src/bin/multiprio.rs | |||
| @@ -126,9 +126,8 @@ static EXECUTOR_LOW: Forever<Executor> = Forever::new(); | |||
| 126 | fn main() -> ! { | 126 | fn main() -> ! { |
| 127 | info!("Hello World!"); | 127 | info!("Hello World!"); |
| 128 | 128 | ||
| 129 | let p = unwrap!(embassy_nrf::Peripherals::take()); | 129 | let p = embassy_nrf::init(Default::default()); |
| 130 | 130 | ||
| 131 | unsafe { embassy_nrf::system::configure(Default::default()) }; | ||
| 132 | let rtc = RTC.put(rtc::RTC::new(p.RTC1, interrupt::take!(RTC1))); | 131 | let rtc = RTC.put(rtc::RTC::new(p.RTC1, interrupt::take!(RTC1))); |
| 133 | rtc.start(); | 132 | rtc.start(); |
| 134 | unsafe { embassy::time::set_clock(rtc) }; | 133 | unsafe { embassy::time::set_clock(rtc) }; |
diff --git a/embassy-nrf-examples/src/bin/ppi.rs b/embassy-nrf-examples/src/bin/ppi.rs index aeda76f21..47782ed29 100644 --- a/embassy-nrf-examples/src/bin/ppi.rs +++ b/embassy-nrf-examples/src/bin/ppi.rs | |||
| @@ -19,46 +19,37 @@ use embassy_nrf::{interrupt, Peripherals}; | |||
| 19 | use gpiote::{OutputChannel, OutputChannelPolarity}; | 19 | use gpiote::{OutputChannel, OutputChannelPolarity}; |
| 20 | 20 | ||
| 21 | #[embassy::main] | 21 | #[embassy::main] |
| 22 | async fn main(spawner: Spawner) { | 22 | async fn main(spawner: Spawner, p: Peripherals) { |
| 23 | let p = Peripherals::take().unwrap(); | ||
| 24 | let g = gpiote::initialize(p.GPIOTE, interrupt::take!(GPIOTE)); | ||
| 25 | |||
| 26 | info!("Starting!"); | 23 | info!("Starting!"); |
| 27 | 24 | ||
| 28 | let button1 = InputChannel::new( | 25 | let button1 = InputChannel::new( |
| 29 | g, | ||
| 30 | p.GPIOTE_CH0, | 26 | p.GPIOTE_CH0, |
| 31 | Input::new(p.P0_11, Pull::Up), | 27 | Input::new(p.P0_11, Pull::Up), |
| 32 | InputChannelPolarity::HiToLo, | 28 | InputChannelPolarity::HiToLo, |
| 33 | ); | 29 | ); |
| 34 | let button2 = InputChannel::new( | 30 | let button2 = InputChannel::new( |
| 35 | g, | ||
| 36 | p.GPIOTE_CH1, | 31 | p.GPIOTE_CH1, |
| 37 | Input::new(p.P0_12, Pull::Up), | 32 | Input::new(p.P0_12, Pull::Up), |
| 38 | InputChannelPolarity::HiToLo, | 33 | InputChannelPolarity::HiToLo, |
| 39 | ); | 34 | ); |
| 40 | let button3 = InputChannel::new( | 35 | let button3 = InputChannel::new( |
| 41 | g, | ||
| 42 | p.GPIOTE_CH2, | 36 | p.GPIOTE_CH2, |
| 43 | Input::new(p.P0_24, Pull::Up), | 37 | Input::new(p.P0_24, Pull::Up), |
| 44 | InputChannelPolarity::HiToLo, | 38 | InputChannelPolarity::HiToLo, |
| 45 | ); | 39 | ); |
| 46 | let button4 = InputChannel::new( | 40 | let button4 = InputChannel::new( |
| 47 | g, | ||
| 48 | p.GPIOTE_CH3, | 41 | p.GPIOTE_CH3, |
| 49 | Input::new(p.P0_25, Pull::Up), | 42 | Input::new(p.P0_25, Pull::Up), |
| 50 | InputChannelPolarity::HiToLo, | 43 | InputChannelPolarity::HiToLo, |
| 51 | ); | 44 | ); |
| 52 | 45 | ||
| 53 | let led1 = OutputChannel::new( | 46 | let led1 = OutputChannel::new( |
| 54 | g, | ||
| 55 | p.GPIOTE_CH4, | 47 | p.GPIOTE_CH4, |
| 56 | Output::new(p.P0_13, Level::Low, OutputDrive::Standard), | 48 | Output::new(p.P0_13, Level::Low, OutputDrive::Standard), |
| 57 | OutputChannelPolarity::Toggle, | 49 | OutputChannelPolarity::Toggle, |
| 58 | ); | 50 | ); |
| 59 | 51 | ||
| 60 | let led2 = OutputChannel::new( | 52 | let led2 = OutputChannel::new( |
| 61 | g, | ||
| 62 | p.GPIOTE_CH5, | 53 | p.GPIOTE_CH5, |
| 63 | Output::new(p.P0_14, Level::Low, OutputDrive::Standard), | 54 | Output::new(p.P0_14, Level::Low, OutputDrive::Standard), |
| 64 | OutputChannelPolarity::Toggle, | 55 | OutputChannelPolarity::Toggle, |
diff --git a/embassy-nrf-examples/src/bin/pwm.rs b/embassy-nrf-examples/src/bin/pwm.rs new file mode 100644 index 000000000..6efcf22d2 --- /dev/null +++ b/embassy-nrf-examples/src/bin/pwm.rs | |||
| @@ -0,0 +1,104 @@ | |||
| 1 | #![no_std] | ||
| 2 | #![no_main] | ||
| 3 | #![feature(min_type_alias_impl_trait)] | ||
| 4 | #![feature(impl_trait_in_bindings)] | ||
| 5 | #![feature(type_alias_impl_trait)] | ||
| 6 | #![allow(incomplete_features)] | ||
| 7 | |||
| 8 | #[path = "../example_common.rs"] | ||
| 9 | mod example_common; | ||
| 10 | use defmt::{panic, *}; | ||
| 11 | use embassy::executor::Spawner; | ||
| 12 | use embassy::time::{Duration, Timer}; | ||
| 13 | use embassy_nrf::pwm::{Prescaler, Pwm}; | ||
| 14 | use embassy_nrf::{interrupt, Peripherals}; | ||
| 15 | |||
| 16 | // for i in range(1024): print(int((math.sin(i/512*math.pi)*0.4+0.5)**2*32767), ', ', end='') | ||
| 17 | static DUTY: [u16; 1024] = [ | ||
| 18 | 8191, 8272, 8353, 8434, 8516, 8598, 8681, 8764, 8847, 8931, 9015, 9099, 9184, 9269, 9354, 9440, | ||
| 19 | 9526, 9613, 9700, 9787, 9874, 9962, 10050, 10139, 10227, 10316, 10406, 10495, 10585, 10675, | ||
| 20 | 10766, 10857, 10948, 11039, 11131, 11223, 11315, 11407, 11500, 11592, 11685, 11779, 11872, | ||
| 21 | 11966, 12060, 12154, 12248, 12343, 12438, 12533, 12628, 12723, 12818, 12914, 13010, 13106, | ||
| 22 | 13202, 13298, 13394, 13491, 13587, 13684, 13781, 13878, 13975, 14072, 14169, 14266, 14364, | ||
| 23 | 14461, 14558, 14656, 14754, 14851, 14949, 15046, 15144, 15242, 15339, 15437, 15535, 15632, | ||
| 24 | 15730, 15828, 15925, 16023, 16120, 16218, 16315, 16412, 16510, 16607, 16704, 16801, 16898, | ||
| 25 | 16995, 17091, 17188, 17284, 17380, 17477, 17572, 17668, 17764, 17859, 17955, 18050, 18145, | ||
| 26 | 18239, 18334, 18428, 18522, 18616, 18710, 18803, 18896, 18989, 19082, 19174, 19266, 19358, | ||
| 27 | 19449, 19540, 19631, 19722, 19812, 19902, 19991, 20081, 20169, 20258, 20346, 20434, 20521, | ||
| 28 | 20608, 20695, 20781, 20867, 20952, 21037, 21122, 21206, 21290, 21373, 21456, 21538, 21620, | ||
| 29 | 21701, 21782, 21863, 21943, 22022, 22101, 22179, 22257, 22335, 22412, 22488, 22564, 22639, | ||
| 30 | 22714, 22788, 22861, 22934, 23007, 23079, 23150, 23220, 23290, 23360, 23429, 23497, 23564, | ||
| 31 | 23631, 23698, 23763, 23828, 23892, 23956, 24019, 24081, 24143, 24204, 24264, 24324, 24383, | ||
| 32 | 24441, 24499, 24555, 24611, 24667, 24721, 24775, 24828, 24881, 24933, 24983, 25034, 25083, | ||
| 33 | 25132, 25180, 25227, 25273, 25319, 25363, 25407, 25451, 25493, 25535, 25575, 25615, 25655, | ||
| 34 | 25693, 25731, 25767, 25803, 25838, 25873, 25906, 25939, 25971, 26002, 26032, 26061, 26089, | ||
| 35 | 26117, 26144, 26170, 26195, 26219, 26242, 26264, 26286, 26307, 26327, 26346, 26364, 26381, | ||
| 36 | 26397, 26413, 26427, 26441, 26454, 26466, 26477, 26487, 26496, 26505, 26512, 26519, 26525, | ||
| 37 | 26530, 26534, 26537, 26539, 26540, 26541, 26540, 26539, 26537, 26534, 26530, 26525, 26519, | ||
| 38 | 26512, 26505, 26496, 26487, 26477, 26466, 26454, 26441, 26427, 26413, 26397, 26381, 26364, | ||
| 39 | 26346, 26327, 26307, 26286, 26264, 26242, 26219, 26195, 26170, 26144, 26117, 26089, 26061, | ||
| 40 | 26032, 26002, 25971, 25939, 25906, 25873, 25838, 25803, 25767, 25731, 25693, 25655, 25615, | ||
| 41 | 25575, 25535, 25493, 25451, 25407, 25363, 25319, 25273, 25227, 25180, 25132, 25083, 25034, | ||
| 42 | 24983, 24933, 24881, 24828, 24775, 24721, 24667, 24611, 24555, 24499, 24441, 24383, 24324, | ||
| 43 | 24264, 24204, 24143, 24081, 24019, 23956, 23892, 23828, 23763, 23698, 23631, 23564, 23497, | ||
| 44 | 23429, 23360, 23290, 23220, 23150, 23079, 23007, 22934, 22861, 22788, 22714, 22639, 22564, | ||
| 45 | 22488, 22412, 22335, 22257, 22179, 22101, 22022, 21943, 21863, 21782, 21701, 21620, 21538, | ||
| 46 | 21456, 21373, 21290, 21206, 21122, 21037, 20952, 20867, 20781, 20695, 20608, 20521, 20434, | ||
| 47 | 20346, 20258, 20169, 20081, 19991, 19902, 19812, 19722, 19631, 19540, 19449, 19358, 19266, | ||
| 48 | 19174, 19082, 18989, 18896, 18803, 18710, 18616, 18522, 18428, 18334, 18239, 18145, 18050, | ||
| 49 | 17955, 17859, 17764, 17668, 17572, 17477, 17380, 17284, 17188, 17091, 16995, 16898, 16801, | ||
| 50 | 16704, 16607, 16510, 16412, 16315, 16218, 16120, 16023, 15925, 15828, 15730, 15632, 15535, | ||
| 51 | 15437, 15339, 15242, 15144, 15046, 14949, 14851, 14754, 14656, 14558, 14461, 14364, 14266, | ||
| 52 | 14169, 14072, 13975, 13878, 13781, 13684, 13587, 13491, 13394, 13298, 13202, 13106, 13010, | ||
| 53 | 12914, 12818, 12723, 12628, 12533, 12438, 12343, 12248, 12154, 12060, 11966, 11872, 11779, | ||
| 54 | 11685, 11592, 11500, 11407, 11315, 11223, 11131, 11039, 10948, 10857, 10766, 10675, 10585, | ||
| 55 | 10495, 10406, 10316, 10227, 10139, 10050, 9962, 9874, 9787, 9700, 9613, 9526, 9440, 9354, 9269, | ||
| 56 | 9184, 9099, 9015, 8931, 8847, 8764, 8681, 8598, 8516, 8434, 8353, 8272, 8191, 8111, 8031, 7952, | ||
| 57 | 7873, 7794, 7716, 7638, 7561, 7484, 7407, 7331, 7255, 7180, 7105, 7031, 6957, 6883, 6810, 6738, | ||
| 58 | 6665, 6594, 6522, 6451, 6381, 6311, 6241, 6172, 6104, 6036, 5968, 5901, 5834, 5767, 5702, 5636, | ||
| 59 | 5571, 5507, 5443, 5379, 5316, 5253, 5191, 5130, 5068, 5008, 4947, 4888, 4828, 4769, 4711, 4653, | ||
| 60 | 4596, 4539, 4482, 4426, 4371, 4316, 4261, 4207, 4153, 4100, 4047, 3995, 3943, 3892, 3841, 3791, | ||
| 61 | 3741, 3691, 3642, 3594, 3546, 3498, 3451, 3404, 3358, 3312, 3267, 3222, 3178, 3134, 3090, 3047, | ||
| 62 | 3005, 2962, 2921, 2879, 2839, 2798, 2758, 2719, 2680, 2641, 2603, 2565, 2528, 2491, 2454, 2418, | ||
| 63 | 2382, 2347, 2312, 2278, 2244, 2210, 2177, 2144, 2112, 2080, 2048, 2017, 1986, 1956, 1926, 1896, | ||
| 64 | 1867, 1838, 1810, 1781, 1754, 1726, 1699, 1673, 1646, 1620, 1595, 1570, 1545, 1520, 1496, 1472, | ||
| 65 | 1449, 1426, 1403, 1380, 1358, 1336, 1315, 1294, 1273, 1252, 1232, 1212, 1192, 1173, 1154, 1135, | ||
| 66 | 1117, 1099, 1081, 1063, 1046, 1029, 1012, 996, 980, 964, 948, 933, 918, 903, 888, 874, 860, | ||
| 67 | 846, 833, 819, 806, 793, 781, 768, 756, 744, 733, 721, 710, 699, 688, 677, 667, 657, 647, 637, | ||
| 68 | 627, 618, 609, 599, 591, 582, 574, 565, 557, 549, 541, 534, 526, 519, 512, 505, 498, 492, 485, | ||
| 69 | 479, 473, 467, 461, 455, 450, 444, 439, 434, 429, 424, 419, 415, 410, 406, 402, 398, 394, 390, | ||
| 70 | 386, 383, 379, 376, 373, 370, 367, 364, 361, 359, 356, 354, 351, 349, 347, 345, 343, 342, 340, | ||
| 71 | 338, 337, 336, 334, 333, 332, 331, 330, 330, 329, 328, 328, 328, 327, 327, 327, 327, 327, 328, | ||
| 72 | 328, 328, 329, 330, 330, 331, 332, 333, 334, 336, 337, 338, 340, 342, 343, 345, 347, 349, 351, | ||
| 73 | 354, 356, 359, 361, 364, 367, 370, 373, 376, 379, 383, 386, 390, 394, 398, 402, 406, 410, 415, | ||
| 74 | 419, 424, 429, 434, 439, 444, 450, 455, 461, 467, 473, 479, 485, 492, 498, 505, 512, 519, 526, | ||
| 75 | 534, 541, 549, 557, 565, 574, 582, 591, 599, 609, 618, 627, 637, 647, 657, 667, 677, 688, 699, | ||
| 76 | 710, 721, 733, 744, 756, 768, 781, 793, 806, 819, 833, 846, 860, 874, 888, 903, 918, 933, 948, | ||
| 77 | 964, 980, 996, 1012, 1029, 1046, 1063, 1081, 1099, 1117, 1135, 1154, 1173, 1192, 1212, 1232, | ||
| 78 | 1252, 1273, 1294, 1315, 1336, 1358, 1380, 1403, 1426, 1449, 1472, 1496, 1520, 1545, 1570, 1595, | ||
| 79 | 1620, 1646, 1673, 1699, 1726, 1754, 1781, 1810, 1838, 1867, 1896, 1926, 1956, 1986, 2017, 2048, | ||
| 80 | 2080, 2112, 2144, 2177, 2210, 2244, 2278, 2312, 2347, 2382, 2418, 2454, 2491, 2528, 2565, 2603, | ||
| 81 | 2641, 2680, 2719, 2758, 2798, 2839, 2879, 2921, 2962, 3005, 3047, 3090, 3134, 3178, 3222, 3267, | ||
| 82 | 3312, 3358, 3404, 3451, 3498, 3546, 3594, 3642, 3691, 3741, 3791, 3841, 3892, 3943, 3995, 4047, | ||
| 83 | 4100, 4153, 4207, 4261, 4316, 4371, 4426, 4482, 4539, 4596, 4653, 4711, 4769, 4828, 4888, 4947, | ||
| 84 | 5008, 5068, 5130, 5191, 5253, 5316, 5379, 5443, 5507, 5571, 5636, 5702, 5767, 5834, 5901, 5968, | ||
| 85 | 6036, 6104, 6172, 6241, 6311, 6381, 6451, 6522, 6594, 6665, 6738, 6810, 6883, 6957, 7031, 7105, | ||
| 86 | 7180, 7255, 7331, 7407, 7484, 7561, 7638, 7716, 7794, 7873, 7952, 8031, 8111, | ||
| 87 | ]; | ||
| 88 | |||
| 89 | #[embassy::main] | ||
| 90 | async fn main(spawner: Spawner, p: Peripherals) { | ||
| 91 | let pwm = Pwm::new(p.PWM0, p.P0_13, p.P0_14, p.P0_16, p.P0_15); | ||
| 92 | pwm.set_prescaler(Prescaler::Div1); | ||
| 93 | info!("pwm initialized!"); | ||
| 94 | |||
| 95 | let mut i = 0; | ||
| 96 | loop { | ||
| 97 | i += 1; | ||
| 98 | pwm.set_duty(0, DUTY[i % 1024]); | ||
| 99 | pwm.set_duty(1, DUTY[(i + 256) % 1024]); | ||
| 100 | pwm.set_duty(2, DUTY[(i + 512) % 1024]); | ||
| 101 | pwm.set_duty(3, DUTY[(i + 768) % 1024]); | ||
| 102 | Timer::after(Duration::from_millis(3)).await; | ||
| 103 | } | ||
| 104 | } | ||
diff --git a/embassy-nrf-examples/src/bin/qspi.rs b/embassy-nrf-examples/src/bin/qspi.rs index 28cde6e51..3dc027f6f 100644 --- a/embassy-nrf-examples/src/bin/qspi.rs +++ b/embassy-nrf-examples/src/bin/qspi.rs | |||
| @@ -23,9 +23,7 @@ const PAGE_SIZE: usize = 4096; | |||
| 23 | struct AlignedBuf([u8; 4096]); | 23 | struct AlignedBuf([u8; 4096]); |
| 24 | 24 | ||
| 25 | #[embassy::main] | 25 | #[embassy::main] |
| 26 | async fn main(spawner: Spawner) { | 26 | async fn main(spawner: Spawner, p: Peripherals) { |
| 27 | let p = Peripherals::take().unwrap(); | ||
| 28 | |||
| 29 | let csn = p.P0_17; | 27 | let csn = p.P0_17; |
| 30 | let sck = p.P0_19; | 28 | let sck = p.P0_19; |
| 31 | let io0 = p.P0_20; | 29 | let io0 = p.P0_20; |
diff --git a/embassy-nrf-examples/src/bin/raw_spawn.rs b/embassy-nrf-examples/src/bin/raw_spawn.rs index f8e021d9b..78de7b100 100644 --- a/embassy-nrf-examples/src/bin/raw_spawn.rs +++ b/embassy-nrf-examples/src/bin/raw_spawn.rs | |||
| @@ -37,9 +37,8 @@ static EXECUTOR: Forever<Executor> = Forever::new(); | |||
| 37 | fn main() -> ! { | 37 | fn main() -> ! { |
| 38 | info!("Hello World!"); | 38 | info!("Hello World!"); |
| 39 | 39 | ||
| 40 | let p = unwrap!(embassy_nrf::Peripherals::take()); | 40 | let p = embassy_nrf::init(Default::default()); |
| 41 | 41 | ||
| 42 | unsafe { embassy_nrf::system::configure(Default::default()) }; | ||
| 43 | let rtc = RTC.put(rtc::RTC::new(p.RTC1, interrupt::take!(RTC1))); | 42 | let rtc = RTC.put(rtc::RTC::new(p.RTC1, interrupt::take!(RTC1))); |
| 44 | rtc.start(); | 43 | rtc.start(); |
| 45 | unsafe { embassy::time::set_clock(rtc) }; | 44 | unsafe { embassy::time::set_clock(rtc) }; |
diff --git a/embassy-nrf-examples/src/bin/spim.rs b/embassy-nrf-examples/src/bin/spim.rs index 27486374f..df921fc86 100644 --- a/embassy-nrf-examples/src/bin/spim.rs +++ b/embassy-nrf-examples/src/bin/spim.rs | |||
| @@ -19,19 +19,14 @@ use embedded_hal::digital::v2::*; | |||
| 19 | use example_common::*; | 19 | use example_common::*; |
| 20 | 20 | ||
| 21 | #[embassy::main] | 21 | #[embassy::main] |
| 22 | async fn main(spawner: Spawner) { | 22 | async fn main(spawner: Spawner, p: Peripherals) { |
| 23 | info!("running!"); | 23 | info!("running!"); |
| 24 | 24 | ||
| 25 | let p = unsafe { Peripherals::steal() }; | 25 | let mut config = spim::Config::default(); |
| 26 | 26 | config.frequency = spim::Frequency::M16; | |
| 27 | let config = spim::Config { | ||
| 28 | frequency: spim::Frequency::M16, | ||
| 29 | mode: spim::MODE_0, | ||
| 30 | orc: 0x00, | ||
| 31 | }; | ||
| 32 | 27 | ||
| 33 | let irq = interrupt::take!(SPIM3); | 28 | let irq = interrupt::take!(SPIM3); |
| 34 | let mut spim = spim::Spim::new(p.SPIM3, irq, p.P0_29, p.P0_28, p.P0_30, config); | 29 | let mut spim = spim::Spim::new(p.SPI3, irq, p.P0_29, p.P0_28, p.P0_30, config); |
| 35 | 30 | ||
| 36 | let mut ncs = Output::new(p.P0_31, Level::High, OutputDrive::Standard); | 31 | let mut ncs = Output::new(p.P0_31, Level::High, OutputDrive::Standard); |
| 37 | 32 | ||
diff --git a/embassy-nrf-examples/src/bin/timer.rs b/embassy-nrf-examples/src/bin/timer.rs index a2b717bc1..ffbbb7841 100644 --- a/embassy-nrf-examples/src/bin/timer.rs +++ b/embassy-nrf-examples/src/bin/timer.rs | |||
| @@ -7,6 +7,7 @@ | |||
| 7 | 7 | ||
| 8 | #[path = "../example_common.rs"] | 8 | #[path = "../example_common.rs"] |
| 9 | mod example_common; | 9 | mod example_common; |
| 10 | use embassy_nrf::Peripherals; | ||
| 10 | use example_common::*; | 11 | use example_common::*; |
| 11 | 12 | ||
| 12 | use defmt::panic; | 13 | use defmt::panic; |
| @@ -30,7 +31,7 @@ async fn run2() { | |||
| 30 | } | 31 | } |
| 31 | 32 | ||
| 32 | #[embassy::main] | 33 | #[embassy::main] |
| 33 | async fn main(spawner: Spawner) { | 34 | async fn main(spawner: Spawner, p: Peripherals) { |
| 34 | unwrap!(spawner.spawn(run1())); | 35 | unwrap!(spawner.spawn(run1())); |
| 35 | unwrap!(spawner.spawn(run2())); | 36 | unwrap!(spawner.spawn(run2())); |
| 36 | } | 37 | } |
diff --git a/embassy-nrf-examples/src/bin/uart.rs b/embassy-nrf-examples/src/bin/uart.rs index 23fc89312..9a0e65d3e 100644 --- a/embassy-nrf-examples/src/bin/uart.rs +++ b/embassy-nrf-examples/src/bin/uart.rs | |||
| @@ -17,9 +17,7 @@ use embassy_nrf::gpio::NoPin; | |||
| 17 | use embassy_nrf::{interrupt, uarte, Peripherals}; | 17 | use embassy_nrf::{interrupt, uarte, Peripherals}; |
| 18 | 18 | ||
| 19 | #[embassy::main] | 19 | #[embassy::main] |
| 20 | async fn main(spawner: Spawner) { | 20 | async fn main(spawner: Spawner, p: Peripherals) { |
| 21 | let p = unsafe { Peripherals::steal() }; | ||
| 22 | |||
| 23 | let mut config = uarte::Config::default(); | 21 | let mut config = uarte::Config::default(); |
| 24 | config.parity = uarte::Parity::EXCLUDED; | 22 | config.parity = uarte::Parity::EXCLUDED; |
| 25 | config.baudrate = uarte::Baudrate::BAUD115200; | 23 | config.baudrate = uarte::Baudrate::BAUD115200; |
| @@ -42,33 +40,5 @@ async fn main(spawner: Spawner) { | |||
| 42 | unwrap!(uart.read(&mut buf).await); | 40 | unwrap!(uart.read(&mut buf).await); |
| 43 | info!("writing..."); | 41 | info!("writing..."); |
| 44 | unwrap!(uart.write(&buf).await); | 42 | unwrap!(uart.write(&buf).await); |
| 45 | |||
| 46 | /* | ||
| 47 | // `receive()` doesn't return until the buffer has been completely filled with | ||
| 48 | // incoming data, which in this case is 8 bytes. | ||
| 49 | // | ||
| 50 | // This example shows how to use `select` to run an uart receive concurrently with a | ||
| 51 | // 1 second timer, effectively adding a timeout to the receive operation. | ||
| 52 | let recv_fut = uart.read(&mut buf); | ||
| 53 | let timer_fut = Timer::after(Duration::from_millis(1000)); | ||
| 54 | let received_len = match select(recv_fut, timer_fut).await { | ||
| 55 | // recv_fut completed first, so we've received `buf_len` bytes. | ||
| 56 | Either::Left(_) => buf_len, | ||
| 57 | // timer_fut completed first. `select` gives us back the future that didn't complete, which | ||
| 58 | // is `recv_fut` in this case, so we can do further stuff with it. | ||
| 59 | // | ||
| 60 | // The recv_fut would stop the uart read automatically when dropped. However, we want to know how | ||
| 61 | // many bytes have been received, so we have to "gracefully stop" it with `.stop()`. | ||
| 62 | Either::Right((_, recv_fut)) => recv_fut.stop().await, | ||
| 63 | }; | ||
| 64 | let received = &mut buf[..received_len]; | ||
| 65 | |||
| 66 | if !received.is_empty() { | ||
| 67 | info!("read done, got {}", received); | ||
| 68 | |||
| 69 | // Echo back received data | ||
| 70 | unwrap!(uart.write(received).await); | ||
| 71 | } | ||
| 72 | */ | ||
| 73 | } | 43 | } |
| 74 | } | 44 | } |
diff --git a/embassy-nrf-examples/src/bin/uart_idle.rs b/embassy-nrf-examples/src/bin/uart_idle.rs index 54d524ae5..a97c65933 100644 --- a/embassy-nrf-examples/src/bin/uart_idle.rs +++ b/embassy-nrf-examples/src/bin/uart_idle.rs | |||
| @@ -18,9 +18,7 @@ use embassy_nrf::gpio::NoPin; | |||
| 18 | use embassy_nrf::{interrupt, uarte, Peripherals}; | 18 | use embassy_nrf::{interrupt, uarte, Peripherals}; |
| 19 | 19 | ||
| 20 | #[embassy::main] | 20 | #[embassy::main] |
| 21 | async fn main(spawner: Spawner) { | 21 | async fn main(spawner: Spawner, p: Peripherals) { |
| 22 | let p = unsafe { Peripherals::steal() }; | ||
| 23 | |||
| 24 | let mut config = uarte::Config::default(); | 22 | let mut config = uarte::Config::default(); |
| 25 | config.parity = uarte::Parity::EXCLUDED; | 23 | config.parity = uarte::Parity::EXCLUDED; |
| 26 | config.baudrate = uarte::Baudrate::BAUD115200; | 24 | config.baudrate = uarte::Baudrate::BAUD115200; |
