X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/a0655e5d30f3cdc73b1aaaa4825d8fae9f92ce4a..8fce4520de1f257819b16f9253fa28dcdae743f4:/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..162186c 100644 --- a/lunaix-os/includes/lunaix/ds/mutex.h +++ b/lunaix-os/includes/lunaix/ds/mutex.h @@ -1,26 +1,34 @@ #ifndef __LUNAIX_MUTEX_H #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 +#include + +typedef struct mutex_s +{ + atomic_ulong lk; + pid_t owner; +} mutex_t; + +static inline void +mutex_init(mutex_t* mutex) +{ + mutex->lk = ATOMIC_VAR_INIT(0); } -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->lk); } -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 */