Semaphore: switch to SREG = oldSREG pattern for interrupt mask/restore

This commit is contained in:
Andrew Tridgell 2012-11-20 22:30:46 +11:00
parent 6836a986f3
commit 833d433caf

View File

@ -22,13 +22,14 @@ AP_Semaphore::AP_Semaphore()
bool AP_Semaphore::get(void* caller) bool AP_Semaphore::get(void* caller)
{ {
bool result = false; bool result = false;
uint8_t oldSREG = SREG;
cli(); cli();
if( !_taken ) { if( !_taken ) {
_taken = true; _taken = true;
_owner = caller; _owner = caller;
result = true; result = true;
} }
sei(); SREG = oldSREG;
return result; return result;
} }
@ -67,12 +68,13 @@ bool AP_Semaphore::release(void* caller)
bool AP_Semaphore::call_on_release(void* caller, ap_semaphore_callback callback_fn) bool AP_Semaphore::call_on_release(void* caller, ap_semaphore_callback callback_fn)
{ {
bool result = false; bool result = false;
uint8_t oldSREG = SREG;
cli(); cli();
if( _waiting_owner == NULL ) { if( _waiting_owner == NULL ) {
_waiting_owner = caller; _waiting_owner = caller;
_waiting_callback = callback_fn; _waiting_callback = callback_fn;
result = true; result = true;
} }
sei(); SREG = oldSREG;
return result; return result;
} }