diff options
| author | Dario Nieuwenhuis <[email protected]> | 2021-02-04 23:56:17 +0100 |
|---|---|---|
| committer | Dario Nieuwenhuis <[email protected]> | 2021-02-04 23:56:17 +0100 |
| commit | a7797a918d3a42f9244a853d2a47aced0ceb900a (patch) | |
| tree | 4ef025641efec64892caf82a710782bb88e84095 /embassy-nrf-examples/src | |
| parent | 18797031533c11ace18160c5917d5131709397ce (diff) | |
nrf/gpiote: new api: switch to owned structs, implement WaitForHigh/WaitForLow.
Diffstat (limited to 'embassy-nrf-examples/src')
| -rw-r--r-- | embassy-nrf-examples/src/bin/gpiote_channel.rs (renamed from embassy-nrf-examples/src/bin/gpiote.rs) | 32 | ||||
| -rw-r--r-- | embassy-nrf-examples/src/bin/gpiote_port.rs | 39 |
2 files changed, 38 insertions, 33 deletions
diff --git a/embassy-nrf-examples/src/bin/gpiote.rs b/embassy-nrf-examples/src/bin/gpiote_channel.rs index f5315d6a6..5470c47cd 100644 --- a/embassy-nrf-examples/src/bin/gpiote.rs +++ b/embassy-nrf-examples/src/bin/gpiote_channel.rs | |||
| @@ -12,7 +12,7 @@ use nrf52840_hal::gpio; | |||
| 12 | 12 | ||
| 13 | use embassy::executor::{task, Executor}; | 13 | use embassy::executor::{task, Executor}; |
| 14 | use embassy::util::Forever; | 14 | use embassy::util::Forever; |
| 15 | use embassy_nrf::gpiote; | 15 | use embassy_nrf::gpiote::{Channels, Gpiote, InputChannel, InputChannelPolarity}; |
| 16 | use embassy_nrf::interrupt; | 16 | use embassy_nrf::interrupt; |
| 17 | 17 | ||
| 18 | #[task] | 18 | #[task] |
| @@ -20,46 +20,44 @@ async fn run() { | |||
| 20 | let p = unwrap!(embassy_nrf::pac::Peripherals::take()); | 20 | let p = unwrap!(embassy_nrf::pac::Peripherals::take()); |
| 21 | let port0 = gpio::p0::Parts::new(p.P0); | 21 | let port0 = gpio::p0::Parts::new(p.P0); |
| 22 | 22 | ||
| 23 | let g = gpiote::Gpiote::new(p.GPIOTE, interrupt::take!(GPIOTE)); | 23 | let (g, chs) = Gpiote::new(p.GPIOTE, interrupt::take!(GPIOTE)); |
| 24 | 24 | ||
| 25 | info!("Starting!"); | 25 | info!("Starting!"); |
| 26 | 26 | ||
| 27 | let pin1 = port0.p0_11.into_pullup_input().degrade(); | 27 | let pin1 = port0.p0_11.into_pullup_input().degrade(); |
| 28 | let button1 = async { | 28 | let pin2 = port0.p0_12.into_pullup_input().degrade(); |
| 29 | let ch = unwrap!(g.new_input_channel(pin1, gpiote::InputChannelPolarity::HiToLo)); | 29 | let pin3 = port0.p0_24.into_pullup_input().degrade(); |
| 30 | let pin4 = port0.p0_25.into_pullup_input().degrade(); | ||
| 31 | |||
| 32 | let ch1 = InputChannel::new(g, chs.ch0, pin1, InputChannelPolarity::HiToLo); | ||
| 33 | let ch2 = InputChannel::new(g, chs.ch1, pin2, InputChannelPolarity::LoToHi); | ||
| 34 | let ch3 = InputChannel::new(g, chs.ch2, pin3, InputChannelPolarity::Toggle); | ||
| 35 | let ch4 = InputChannel::new(g, chs.ch3, pin4, InputChannelPolarity::Toggle); | ||
| 30 | 36 | ||
| 37 | let button1 = async { | ||
| 31 | loop { | 38 | loop { |
| 32 | ch.wait().await; | 39 | ch1.wait().await; |
| 33 | info!("Button 1 pressed") | 40 | info!("Button 1 pressed") |
| 34 | } | 41 | } |
| 35 | }; | 42 | }; |
| 36 | 43 | ||
| 37 | let pin2 = port0.p0_12.into_pullup_input().degrade(); | ||
| 38 | let button2 = async { | 44 | let button2 = async { |
| 39 | let ch = unwrap!(g.new_input_channel(pin2, gpiote::InputChannelPolarity::LoToHi)); | ||
| 40 | |||
| 41 | loop { | 45 | loop { |
| 42 | ch.wait().await; | 46 | ch2.wait().await; |
| 43 | info!("Button 2 released") | 47 | info!("Button 2 released") |
| 44 | } | 48 | } |
| 45 | }; | 49 | }; |
| 46 | 50 | ||
| 47 | let pin3 = port0.p0_24.into_pullup_input().degrade(); | ||
| 48 | let button3 = async { | 51 | let button3 = async { |
| 49 | let ch = unwrap!(g.new_input_channel(pin3, gpiote::InputChannelPolarity::Toggle)); | ||
| 50 | |||
| 51 | loop { | 52 | loop { |
| 52 | ch.wait().await; | 53 | ch3.wait().await; |
| 53 | info!("Button 3 toggled") | 54 | info!("Button 3 toggled") |
| 54 | } | 55 | } |
| 55 | }; | 56 | }; |
| 56 | 57 | ||
| 57 | let pin4 = port0.p0_25.into_pullup_input().degrade(); | ||
| 58 | let button4 = async { | 58 | let button4 = async { |
| 59 | let ch = unwrap!(g.new_input_channel(pin4, gpiote::InputChannelPolarity::Toggle)); | ||
| 60 | |||
| 61 | loop { | 59 | loop { |
| 62 | ch.wait().await; | 60 | ch4.wait().await; |
| 63 | info!("Button 4 toggled") | 61 | info!("Button 4 toggled") |
| 64 | } | 62 | } |
| 65 | }; | 63 | }; |
diff --git a/embassy-nrf-examples/src/bin/gpiote_port.rs b/embassy-nrf-examples/src/bin/gpiote_port.rs index 833096f3a..9d999f951 100644 --- a/embassy-nrf-examples/src/bin/gpiote_port.rs +++ b/embassy-nrf-examples/src/bin/gpiote_port.rs | |||
| @@ -7,20 +7,22 @@ mod example_common; | |||
| 7 | use example_common::*; | 7 | use example_common::*; |
| 8 | 8 | ||
| 9 | use core::mem; | 9 | use core::mem; |
| 10 | use core::pin::Pin; | ||
| 10 | use cortex_m_rt::entry; | 11 | use cortex_m_rt::entry; |
| 11 | use defmt::panic; | 12 | use defmt::panic; |
| 12 | use nrf52840_hal::gpio; | 13 | use nrf52840_hal::gpio; |
| 13 | 14 | ||
| 14 | use embassy::executor::{task, Executor}; | 15 | use embassy::executor::{task, Executor}; |
| 16 | use embassy::gpio::{WaitForHigh, WaitForLow}; | ||
| 15 | use embassy::util::Forever; | 17 | use embassy::util::Forever; |
| 16 | use embassy_nrf::gpiote::{Gpiote, PortInputPolarity}; | 18 | use embassy_nrf::gpiote::{Gpiote, GpiotePin}; |
| 17 | use embassy_nrf::interrupt; | 19 | use embassy_nrf::interrupt; |
| 18 | 20 | ||
| 19 | async fn button(g: &Gpiote, n: usize, pin: gpio::Pin<gpio::Input<gpio::PullUp>>) { | 21 | async fn button(n: usize, mut pin: GpiotePin<gpio::PullUp>) { |
| 20 | loop { | 22 | loop { |
| 21 | g.wait_port_input(&pin, PortInputPolarity::Low).await; | 23 | Pin::new(&mut pin).wait_for_low().await; |
| 22 | info!("Button {:?} pressed!", n); | 24 | info!("Button {:?} pressed!", n); |
| 23 | g.wait_port_input(&pin, PortInputPolarity::High).await; | 25 | Pin::new(&mut pin).wait_for_high().await; |
| 24 | info!("Button {:?} released!", n); | 26 | info!("Button {:?} released!", n); |
| 25 | } | 27 | } |
| 26 | } | 28 | } |
| @@ -30,19 +32,24 @@ async fn run() { | |||
| 30 | let p = unwrap!(embassy_nrf::pac::Peripherals::take()); | 32 | let p = unwrap!(embassy_nrf::pac::Peripherals::take()); |
| 31 | let port0 = gpio::p0::Parts::new(p.P0); | 33 | let port0 = gpio::p0::Parts::new(p.P0); |
| 32 | 34 | ||
| 33 | let g = Gpiote::new(p.GPIOTE, interrupt::take!(GPIOTE)); | 35 | let (g, _) = Gpiote::new(p.GPIOTE, interrupt::take!(GPIOTE)); |
| 34 | info!( | ||
| 35 | "sizeof Signal<()> = {:usize}", | ||
| 36 | mem::size_of::<embassy::util::Signal<()>>() | ||
| 37 | ); | ||
| 38 | info!("sizeof gpiote = {:usize}", mem::size_of::<Gpiote>()); | ||
| 39 | |||
| 40 | info!("Starting!"); | ||
| 41 | 36 | ||
| 42 | let button1 = button(&g, 1, port0.p0_11.into_pullup_input().degrade()); | 37 | let button1 = button( |
| 43 | let button2 = button(&g, 2, port0.p0_12.into_pullup_input().degrade()); | 38 | 1, |
| 44 | let button3 = button(&g, 3, port0.p0_24.into_pullup_input().degrade()); | 39 | GpiotePin::new(g, port0.p0_11.into_pullup_input().degrade()), |
| 45 | let button4 = button(&g, 4, port0.p0_25.into_pullup_input().degrade()); | 40 | ); |
| 41 | let button2 = button( | ||
| 42 | 2, | ||
| 43 | GpiotePin::new(g, port0.p0_12.into_pullup_input().degrade()), | ||
| 44 | ); | ||
| 45 | let button3 = button( | ||
| 46 | 3, | ||
| 47 | GpiotePin::new(g, port0.p0_24.into_pullup_input().degrade()), | ||
| 48 | ); | ||
| 49 | let button4 = button( | ||
| 50 | 4, | ||
| 51 | GpiotePin::new(g, port0.p0_25.into_pullup_input().degrade()), | ||
| 52 | ); | ||
| 46 | futures::join!(button1, button2, button3, button4); | 53 | futures::join!(button1, button2, button3, button4); |
| 47 | } | 54 | } |
| 48 | 55 | ||
