From da6f6f3e41299313f39c7eca5bf0c145bcb85c28 Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Tue, 20 Nov 2012 22:30:35 +1100 Subject: [PATCH] PeriodicProcess: switch to SREG = oldSREG pattern for interrupt mask/restore --- libraries/AP_PeriodicProcess/AP_TimerProcess.cpp | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/libraries/AP_PeriodicProcess/AP_TimerProcess.cpp b/libraries/AP_PeriodicProcess/AP_TimerProcess.cpp index 7ea4fe62ce..0d8c9d0c01 100644 --- a/libraries/AP_PeriodicProcess/AP_TimerProcess.cpp +++ b/libraries/AP_PeriodicProcess/AP_TimerProcess.cpp @@ -56,10 +56,11 @@ void AP_TimerProcess::register_process(ap_procedure proc) for (uint8_t i=0; i<_pidx; i++) { if (_proc[i] == proc) return; } + uint8_t oldSREG = SREG; cli(); if (_pidx < AP_TIMERPROCESS_MAX_PROCS) _proc[_pidx++] = proc; - sei(); + SREG = oldSREG; } void AP_TimerProcess::set_failsafe(ap_procedure proc) @@ -140,10 +141,11 @@ void AP_TimerProcess::run(void) } // run any queued processes + uint8_t oldSREG = SREG; cli(); ap_procedure qp = _queued_proc; _queued_proc = NULL; - sei(); + SREG = oldSREG; if( qp != NULL ) { _suspended = true; qp(tnow);