2020-09-22 22:32:49 +00:00
|
|
|
#![no_std]
|
|
|
|
#![no_main]
|
|
|
|
#![feature(type_alias_impl_trait)]
|
|
|
|
|
|
|
|
#[path = "../example_common.rs"]
|
|
|
|
mod example_common;
|
|
|
|
use example_common::*;
|
|
|
|
|
|
|
|
use cortex_m_rt::entry;
|
2020-12-29 00:53:17 +00:00
|
|
|
use defmt::panic;
|
2020-09-22 22:32:49 +00:00
|
|
|
use nrf52840_hal::gpio;
|
|
|
|
|
2020-10-19 19:15:24 +00:00
|
|
|
use embassy::executor::{task, Executor};
|
2020-10-31 21:37:24 +00:00
|
|
|
use embassy::util::Forever;
|
2021-02-14 00:41:36 +00:00
|
|
|
use embassy_nrf::gpiote::{Gpiote, InputChannel, InputChannelPolarity};
|
2020-12-29 00:53:17 +00:00
|
|
|
use embassy_nrf::interrupt;
|
2020-09-24 20:04:45 +00:00
|
|
|
|
|
|
|
#[task]
|
2020-09-22 22:32:49 +00:00
|
|
|
async fn run() {
|
2020-11-01 16:17:24 +00:00
|
|
|
let p = unwrap!(embassy_nrf::pac::Peripherals::take());
|
2020-09-22 22:32:49 +00:00
|
|
|
let port0 = gpio::p0::Parts::new(p.P0);
|
|
|
|
|
2021-02-04 22:56:17 +00:00
|
|
|
let (g, chs) = Gpiote::new(p.GPIOTE, interrupt::take!(GPIOTE));
|
2020-09-22 22:32:49 +00:00
|
|
|
|
|
|
|
info!("Starting!");
|
|
|
|
|
|
|
|
let pin1 = port0.p0_11.into_pullup_input().degrade();
|
2021-02-04 22:56:17 +00:00
|
|
|
let pin2 = port0.p0_12.into_pullup_input().degrade();
|
|
|
|
let pin3 = port0.p0_24.into_pullup_input().degrade();
|
|
|
|
let pin4 = port0.p0_25.into_pullup_input().degrade();
|
|
|
|
|
|
|
|
let ch1 = InputChannel::new(g, chs.ch0, pin1, InputChannelPolarity::HiToLo);
|
|
|
|
let ch2 = InputChannel::new(g, chs.ch1, pin2, InputChannelPolarity::LoToHi);
|
|
|
|
let ch3 = InputChannel::new(g, chs.ch2, pin3, InputChannelPolarity::Toggle);
|
|
|
|
let ch4 = InputChannel::new(g, chs.ch3, pin4, InputChannelPolarity::Toggle);
|
2020-09-22 22:32:49 +00:00
|
|
|
|
2021-02-04 22:56:17 +00:00
|
|
|
let button1 = async {
|
2020-09-22 22:32:49 +00:00
|
|
|
loop {
|
2021-02-04 22:56:17 +00:00
|
|
|
ch1.wait().await;
|
2020-09-22 22:32:49 +00:00
|
|
|
info!("Button 1 pressed")
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
let button2 = async {
|
|
|
|
loop {
|
2021-02-04 22:56:17 +00:00
|
|
|
ch2.wait().await;
|
2020-09-22 22:32:49 +00:00
|
|
|
info!("Button 2 released")
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
let button3 = async {
|
|
|
|
loop {
|
2021-02-04 22:56:17 +00:00
|
|
|
ch3.wait().await;
|
2020-09-22 22:32:49 +00:00
|
|
|
info!("Button 3 toggled")
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
let button4 = async {
|
|
|
|
loop {
|
2021-02-04 22:56:17 +00:00
|
|
|
ch4.wait().await;
|
2020-09-22 22:32:49 +00:00
|
|
|
info!("Button 4 toggled")
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
futures::join!(button1, button2, button3, button4);
|
|
|
|
}
|
|
|
|
|
2020-10-31 21:37:24 +00:00
|
|
|
static EXECUTOR: Forever<Executor> = Forever::new();
|
|
|
|
|
2020-09-22 22:32:49 +00:00
|
|
|
#[entry]
|
|
|
|
fn main() -> ! {
|
|
|
|
info!("Hello World!");
|
|
|
|
|
2021-02-02 04:14:52 +00:00
|
|
|
let executor = EXECUTOR.put(Executor::new());
|
|
|
|
executor.run(|spawner| {
|
|
|
|
unwrap!(spawner.spawn(run()));
|
|
|
|
});
|
2020-09-22 22:32:49 +00:00
|
|
|
}
|