X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/a0655e5d30f3cdc73b1aaaa4825d8fae9f92ce4a..0eabc11fcf240415e39f3873dfce7cd9384b3042:/lunaix-os/includes/lunaix/ds/mutex.h diff --git a/lunaix-os/includes/lunaix/ds/mutex.h b/lunaix-os/includes/lunaix/ds/mutex.h index 5e166e5..97101ef 100644 --- a/lunaix-os/includes/lunaix/ds/mutex.h +++ b/lunaix-os/includes/lunaix/ds/mutex.h @@ -2,25 +2,33 @@ #define __LUNAIX_MUTEX_H #include "semaphore.h" - -// TODO: implement mutex lock - -typedef struct sem_t mutex_t; - -static inline void mutex_init(mutex_t *mutex) { - sem_init(mutex, 1); +#include + +typedef struct mutex_s +{ + struct sem_t sem; + pid_t owner; +} mutex_t; + +static inline void +mutex_init(mutex_t* mutex) +{ + sem_init(&mutex->sem, 1); } -static inline unsigned int mutex_on_hold(mutex_t *mutex) { - return !atomic_load(&mutex->counter); +static inline int +mutex_on_hold(mutex_t* mutex) +{ + return !atomic_load(&mutex->sem.counter); } -static inline void mutex_lock(mutex_t *mutex) { - sem_wait(mutex); -} +void +mutex_lock(mutex_t* mutex); -static inline void mutex_unlock(mutex_t *mutex) { - sem_post(mutex); -} +void +mutex_unlock(mutex_t* mutex); + +void +mutex_unlock_for(mutex_t* mutex, pid_t pid); #endif /* __LUNAIX_MUTEX_H */