2021-09-14 07:59:55 -06:00
|
|
|
#![no_std]
|
|
|
|
#![no_main]
|
|
|
|
|
|
|
|
use panic_halt as _;
|
|
|
|
|
2021-12-23 11:18:52 +00:00
|
|
|
#[rtic::app(device = rp_pico::hal::pac, peripherals = true)]
|
2021-09-14 07:59:55 -06:00
|
|
|
mod app {
|
|
|
|
|
|
|
|
use embedded_hal::digital::v2::OutputPin;
|
2022-08-31 21:45:08 +01:00
|
|
|
use fugit::MicrosDurationU32;
|
2021-12-23 11:18:52 +00:00
|
|
|
use rp_pico::{
|
2022-04-17 23:03:11 +01:00
|
|
|
hal::{self, clocks::init_clocks_and_plls, timer::Alarm, watchdog::Watchdog, Sio},
|
2021-09-14 07:59:55 -06:00
|
|
|
XOSC_CRYSTAL_FREQ,
|
|
|
|
};
|
|
|
|
|
2022-08-31 21:45:08 +01:00
|
|
|
const SCAN_TIME_US: MicrosDurationU32 = MicrosDurationU32::secs(1);
|
2021-09-14 07:59:55 -06:00
|
|
|
|
|
|
|
#[shared]
|
|
|
|
struct Shared {
|
2021-12-07 19:24:35 -05:00
|
|
|
timer: hal::Timer,
|
|
|
|
alarm: hal::timer::Alarm0,
|
2021-09-14 07:59:55 -06:00
|
|
|
led: hal::gpio::Pin<hal::gpio::pin::bank0::Gpio25, hal::gpio::PushPullOutput>,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[local]
|
|
|
|
struct Local {}
|
|
|
|
|
|
|
|
#[init]
|
|
|
|
fn init(c: init::Context) -> (Shared, Local, init::Monotonics) {
|
2022-04-11 19:52:14 +10:00
|
|
|
// Soft-reset does not release the hardware spinlocks
|
|
|
|
// Release them now to avoid a deadlock after debug or watchdog reset
|
|
|
|
unsafe {
|
|
|
|
hal::sio::spinlock_reset();
|
|
|
|
}
|
2021-09-14 07:59:55 -06:00
|
|
|
let mut resets = c.device.RESETS;
|
|
|
|
let mut watchdog = Watchdog::new(c.device.WATCHDOG);
|
|
|
|
let _clocks = init_clocks_and_plls(
|
|
|
|
XOSC_CRYSTAL_FREQ,
|
|
|
|
c.device.XOSC,
|
|
|
|
c.device.CLOCKS,
|
|
|
|
c.device.PLL_SYS,
|
|
|
|
c.device.PLL_USB,
|
|
|
|
&mut resets,
|
|
|
|
&mut watchdog,
|
|
|
|
)
|
|
|
|
.ok()
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
let sio = Sio::new(c.device.SIO);
|
2021-12-23 11:18:52 +00:00
|
|
|
let pins = rp_pico::Pins::new(
|
2021-09-14 07:59:55 -06:00
|
|
|
c.device.IO_BANK0,
|
|
|
|
c.device.PADS_BANK0,
|
|
|
|
sio.gpio_bank0,
|
|
|
|
&mut resets,
|
|
|
|
);
|
2021-12-07 19:24:35 -05:00
|
|
|
let mut led = pins.led.into_push_pull_output();
|
2021-09-14 07:59:55 -06:00
|
|
|
led.set_low().unwrap();
|
|
|
|
|
2021-12-07 19:24:35 -05:00
|
|
|
let mut timer = hal::Timer::new(c.device.TIMER, &mut resets);
|
|
|
|
let mut alarm = timer.alarm_0().unwrap();
|
2022-08-18 20:14:51 +01:00
|
|
|
let _ = alarm.schedule(SCAN_TIME_US);
|
2022-01-30 23:04:16 +11:00
|
|
|
alarm.enable_interrupt();
|
2021-09-14 07:59:55 -06:00
|
|
|
|
2021-12-07 19:24:35 -05:00
|
|
|
(Shared { timer, alarm, led }, Local {}, init::Monotonics())
|
2021-09-14 07:59:55 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
#[task(
|
|
|
|
binds = TIMER_IRQ_0,
|
|
|
|
priority = 1,
|
2021-12-07 19:24:35 -05:00
|
|
|
shared = [timer, alarm, led],
|
|
|
|
local = [tog: bool = true],
|
2021-09-14 07:59:55 -06:00
|
|
|
)]
|
2021-12-07 19:24:35 -05:00
|
|
|
fn timer_irq(mut c: timer_irq::Context) {
|
2021-09-14 07:59:55 -06:00
|
|
|
if *c.local.tog {
|
|
|
|
c.shared.led.lock(|l| l.set_high().unwrap());
|
|
|
|
} else {
|
|
|
|
c.shared.led.lock(|l| l.set_low().unwrap());
|
|
|
|
}
|
|
|
|
*c.local.tog = !*c.local.tog;
|
|
|
|
|
2022-01-30 23:04:16 +11:00
|
|
|
let mut alarm = c.shared.alarm;
|
|
|
|
(alarm).lock(|a| {
|
|
|
|
a.clear_interrupt();
|
2022-08-18 20:14:51 +01:00
|
|
|
let _ = a.schedule(SCAN_TIME_US);
|
2021-09-14 07:59:55 -06:00
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|