2021-10-26 00:37:52 -07:00
|
|
|
#![no_std]
|
|
|
|
#![no_main]
|
|
|
|
#![feature(type_alias_impl_trait)]
|
|
|
|
|
|
|
|
use defmt::*;
|
|
|
|
use embassy::executor::Spawner;
|
|
|
|
use embassy::time::{Duration, Timer};
|
2022-06-12 22:15:44 +02:00
|
|
|
use embassy_nrf::pwm::{Config, Prescaler, SequenceConfig, SequencePwm, SingleSequenceMode, SingleSequencer};
|
2021-10-26 00:37:52 -07:00
|
|
|
use embassy_nrf::Peripherals;
|
2022-06-12 22:15:44 +02:00
|
|
|
use {defmt_rtt as _, panic_probe as _};
|
2022-04-02 04:35:06 +02:00
|
|
|
|
2021-10-26 00:37:52 -07:00
|
|
|
#[embassy::main]
|
|
|
|
async fn main(_spawner: Spawner, p: Peripherals) {
|
2022-02-04 19:11:15 +11:00
|
|
|
let seq_words: [u16; 5] = [1000, 250, 100, 50, 0];
|
2022-01-30 16:21:23 +11:00
|
|
|
|
2022-01-25 18:06:42 +11:00
|
|
|
let mut config = Config::default();
|
2021-11-11 23:27:03 -07:00
|
|
|
config.prescaler = Prescaler::Div128;
|
2022-01-25 16:51:24 +11:00
|
|
|
// 1 period is 1000 * (128/16mhz = 0.000008s = 0.008ms) = 8us
|
2021-11-11 23:27:03 -07:00
|
|
|
// but say we want to hold the value for 5000ms
|
|
|
|
// so we want to repeat our value as many times as necessary until 5000ms passes
|
|
|
|
// want 5000/8 = 625 periods total to occur, so 624 (we get the one period for free remember)
|
2022-01-28 13:38:20 +11:00
|
|
|
let mut seq_config = SequenceConfig::default();
|
2022-01-25 18:06:42 +11:00
|
|
|
seq_config.refresh = 624;
|
2021-11-11 23:47:35 -07:00
|
|
|
// thus our sequence takes 5 * 5000ms or 25 seconds
|
2021-10-26 00:37:52 -07:00
|
|
|
|
2022-02-12 01:04:01 +01:00
|
|
|
let mut pwm = unwrap!(SequencePwm::new_1ch(p.PWM0, p.P0_13, config,));
|
2022-02-04 16:34:25 +11:00
|
|
|
|
2022-02-05 08:05:23 +11:00
|
|
|
let sequencer = SingleSequencer::new(&mut pwm, &seq_words, seq_config);
|
2022-02-04 19:11:15 +11:00
|
|
|
unwrap!(sequencer.start(SingleSequenceMode::Times(1)));
|
2022-01-23 16:21:34 +11:00
|
|
|
|
2021-11-11 23:47:35 -07:00
|
|
|
// we can abort a sequence if we need to before its complete with pwm.stop()
|
|
|
|
// or stop is also implicitly called when the pwm peripheral is dropped
|
|
|
|
// when it goes out of scope
|
|
|
|
Timer::after(Duration::from_millis(20000)).await;
|
|
|
|
info!("pwm stopped early!");
|
2021-10-26 00:37:52 -07:00
|
|
|
}
|