AP_HAL_SITL: only disown a sempahore once we're done with it

This commit is contained in:
Peter Barker 2020-11-12 18:45:09 +11:00 committed by Peter Barker
parent 545a086865
commit a9a2c8c392
2 changed files with 14 additions and 2 deletions

View File

@ -21,10 +21,13 @@ Semaphore::Semaphore()
bool Semaphore::give()
{
take_count--;
if (pthread_mutex_unlock(&_lock) != 0) {
AP_HAL::panic("Bad semaphore usage");
}
owner = (pthread_t)-1;
if (take_count == 0) {
owner = (pthread_t)-1;
}
return true;
}
@ -41,6 +44,7 @@ bool Semaphore::take(uint32_t timeout_ms)
if (timeout_ms == HAL_SEMAPHORE_BLOCK_FOREVER) {
if (pthread_mutex_lock(&_lock) == 0) {
owner = pthread_self();
take_count++;
return true;
}
return false;
@ -64,7 +68,12 @@ bool Semaphore::take(uint32_t timeout_ms)
bool Semaphore::take_nonblocking()
{
return pthread_mutex_trylock(&_lock) == 0;
if (pthread_mutex_trylock(&_lock) == 0) {
owner = pthread_self();
take_count++;
return true;
}
return false;
}
#endif // CONFIG_HAL_BOARD

View File

@ -20,4 +20,7 @@ protected:
pthread_mutex_t _lock;
pthread_t owner;
// keep track the recursion level to ensure we only disown the
// semaphore once we're done with it
uint8_t take_count;
};