2013-06-22 05:11:53 +02:00
|
|
|
/**
|
|
|
|
* Semaphore implemenation
|
|
|
|
*
|
|
|
|
* Copyright (C) 2013 INRIA.
|
|
|
|
*
|
|
|
|
* This file subject to the terms and conditions of the GNU Lesser General
|
|
|
|
* Public License. See the file LICENSE in the top level directory for more
|
|
|
|
* details.
|
|
|
|
*
|
|
|
|
* @ingroup sixlowpan
|
|
|
|
* @{
|
|
|
|
* @file semaphore.c
|
|
|
|
* @brief Implemntation of semaphores using mutexes
|
|
|
|
* @author Martin Lenders <mlenders@inf.fu-berlin.de>
|
|
|
|
* @author Oliver Hahm <oliver.hahm@inria.fr>
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
2011-07-09 20:34:20 +02:00
|
|
|
#include <mutex.h>
|
|
|
|
|
2011-07-28 18:25:57 +02:00
|
|
|
#include "semaphore.h"
|
|
|
|
|
2013-06-22 05:11:53 +02:00
|
|
|
void sem_init(sem_t *sem, int8_t value)
|
|
|
|
{
|
2011-07-28 18:25:57 +02:00
|
|
|
sem->value = value;
|
|
|
|
mutex_init(&sem->mutex);
|
|
|
|
sem->locked = 0;
|
2011-07-09 20:34:20 +02:00
|
|
|
}
|
|
|
|
|
2013-06-22 05:11:53 +02:00
|
|
|
int sem_wait(sem_t *sem)
|
|
|
|
{
|
2011-07-09 20:34:20 +02:00
|
|
|
int res;
|
2013-06-22 05:11:53 +02:00
|
|
|
|
2013-06-24 22:37:35 +02:00
|
|
|
if (--(sem->value) <= 0 && !sem->locked) {
|
2011-07-09 20:34:20 +02:00
|
|
|
sem->locked = !(sem->locked);
|
|
|
|
res = mutex_lock(&(sem->mutex));
|
2013-06-22 05:11:53 +02:00
|
|
|
|
2013-06-24 22:37:35 +02:00
|
|
|
if (res < 0) {
|
2011-07-09 20:34:20 +02:00
|
|
|
return res;
|
|
|
|
}
|
|
|
|
}
|
2013-06-22 05:11:53 +02:00
|
|
|
|
2011-07-09 20:34:20 +02:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2013-06-22 05:11:53 +02:00
|
|
|
int sem_signal(sem_t *sem)
|
|
|
|
{
|
2013-06-24 22:37:35 +02:00
|
|
|
if (++(sem->value) > 0 && sem->locked) {
|
2011-07-09 20:34:20 +02:00
|
|
|
sem->locked = !(sem->locked);
|
2013-08-04 04:06:31 +02:00
|
|
|
mutex_unlock(&(sem->mutex));
|
2011-07-09 20:34:20 +02:00
|
|
|
}
|
2013-06-22 05:11:53 +02:00
|
|
|
|
2011-07-09 20:34:20 +02:00
|
|
|
return 0;
|
|
|
|
}
|