Merge pull request #272 from 9names/watchdog_fix

Set hw reset bits for watchdog
This commit is contained in:
9names 2022-02-20 16:46:12 +11:00 committed by GitHub
commit 4075f81b2d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -92,6 +92,21 @@ impl Watchdog {
fn enable(&self, bit: bool) { fn enable(&self, bit: bool) {
self.watchdog.ctrl.write(|w| w.enable().bit(bit)) self.watchdog.ctrl.write(|w| w.enable().bit(bit))
} }
/// Configure which hardware will be reset by the watchdog
/// the default is everything except ROSC, XOSC
///
/// Safety: ensure no other device is writing to psm.wdsel
/// This is easy at the moment, since nothing else uses PSM
unsafe fn configure_wdog_reset_triggers(&self) {
let psm = &*pac::PSM::ptr();
psm.wdsel.write_with_zero(|w| {
w.bits(0x0001ffff);
w.xosc().clear_bit();
w.rosc().clear_bit();
w
});
}
} }
impl watchdog::Watchdog for Watchdog { impl watchdog::Watchdog for Watchdog {
@ -124,6 +139,9 @@ impl watchdog::WatchdogEnable for Watchdog {
} }
self.enable(false); self.enable(false);
unsafe {
self.configure_wdog_reset_triggers();
}
self.load_counter(self.delay_ms); self.load_counter(self.delay_ms);
self.enable(true); self.enable(true);
} }