aboutsummaryrefslogtreecommitdiff
path: root/embassy-nrf-examples/src
diff options
context:
space:
mode:
authorDario Nieuwenhuis <[email protected]>2021-02-04 23:56:17 +0100
committerDario Nieuwenhuis <[email protected]>2021-02-04 23:56:17 +0100
commita7797a918d3a42f9244a853d2a47aced0ceb900a (patch)
tree4ef025641efec64892caf82a710782bb88e84095 /embassy-nrf-examples/src
parent18797031533c11ace18160c5917d5131709397ce (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.rs39
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
13use embassy::executor::{task, Executor}; 13use embassy::executor::{task, Executor};
14use embassy::util::Forever; 14use embassy::util::Forever;
15use embassy_nrf::gpiote; 15use embassy_nrf::gpiote::{Channels, Gpiote, InputChannel, InputChannelPolarity};
16use embassy_nrf::interrupt; 16use 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;
7use example_common::*; 7use example_common::*;
8 8
9use core::mem; 9use core::mem;
10use core::pin::Pin;
10use cortex_m_rt::entry; 11use cortex_m_rt::entry;
11use defmt::panic; 12use defmt::panic;
12use nrf52840_hal::gpio; 13use nrf52840_hal::gpio;
13 14
14use embassy::executor::{task, Executor}; 15use embassy::executor::{task, Executor};
16use embassy::gpio::{WaitForHigh, WaitForLow};
15use embassy::util::Forever; 17use embassy::util::Forever;
16use embassy_nrf::gpiote::{Gpiote, PortInputPolarity}; 18use embassy_nrf::gpiote::{Gpiote, GpiotePin};
17use embassy_nrf::interrupt; 19use embassy_nrf::interrupt;
18 20
19async fn button(g: &Gpiote, n: usize, pin: gpio::Pin<gpio::Input<gpio::PullUp>>) { 21async 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