mirror of
https://github.com/italicsjenga/rp-hal-boards.git
synced 2025-01-23 09:46:33 +11:00
Merge pull request #263 from WeirdConstructor/fix_alarm_schedule_race_cond
Fix alarm schedule race condition
This commit is contained in:
commit
d3c9c3b4e2
1 changed files with 12 additions and 10 deletions
|
@ -249,17 +249,19 @@ macro_rules! impl_alarm {
|
|||
if duration < MIN_MICROSECONDS {
|
||||
return Err(ScheduleAlarmError::AlarmTooSoon);
|
||||
} else {
|
||||
// safety: This is a read action and should not have any UB
|
||||
let target_time = unsafe { &*TIMER::ptr() }
|
||||
.timelr
|
||||
.read()
|
||||
.bits()
|
||||
.wrapping_add(duration);
|
||||
cortex_m::interrupt::free(|_| {
|
||||
// safety: This is a read action and should not have any UB
|
||||
let target_time = unsafe { &*TIMER::ptr() }
|
||||
.timelr
|
||||
.read()
|
||||
.bits()
|
||||
.wrapping_add(duration);
|
||||
|
||||
// safety: This is the only code in the codebase that accesses memory address $timer_alarm
|
||||
unsafe { &*TIMER::ptr() }
|
||||
.$timer_alarm
|
||||
.write(|w| unsafe { w.bits(target_time) });
|
||||
// safety: This is the only code in the codebase that accesses memory address $timer_alarm
|
||||
unsafe { &*TIMER::ptr() }
|
||||
.$timer_alarm
|
||||
.write(|w| unsafe { w.bits(target_time) });
|
||||
});
|
||||
Ok(())
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue